This chapter includes the following sections:
Version control and source control help teams coordinate work. Version control tracks application changes against project management or bug reporting systems, and developers check in code into a commonly used repository of content that is built into a functioning product.
Developing in teams often requires coordination among multiple developers who may be called upon to make changes to the same files, to track these changes against project management or bug reporting systems, and eventually to check in or commit their edited files to a commonly used repository of content that will be built into a functioning product.
At least one team member is typically required to administer and maintain the versioning system as it relates to JDeveloper. If you are the administrator for your versioning system, you will most likely have additional tasks beyond checking files in and out.
Integrate a version control system with JDeveloper and download a JDeveloper Extension using Check for Updates from Help. Downloadable extensions are available for CVS, Mercurial, Perforce, and Microsoft Team System.
For users familiar with other versioning systems, or whose teams use systems other than Subversion and Git, JDeveloper provides downloadable extensions that give you access to the following:
Concurrent Version System (CVS) How to Set Up CVS with JDeveloper
Mercurial
Microsoft Team System How to Set Up Team System and JDeveloper
If your team requires you to download a JDeveloper Extension to integrate your versioning system with JDeveloper, you can browse for the versioning system from the Update Center by selecting Help > Check for Updates. Be sure to select all update centers when you search for your versioning system.
Besides integrated solutions such as Subversion and Git, JDeveloper supports extensions such as Mercurial, and an application lifecycle management system. Access commands for the systems from the Team menu or from the Versions window.
JDeveloper offers several tools for developing in teams. These include integrated solutions such as Subversion and Git, as well as downloadable extensions such as Mercurial. You can access commands for all of these systems directly from the JDeveloper interface, through the Team menu or through the Versions window
JDeveloper is integrated with the popular team development solution Subversion (SVN). If you are part of a team that uses Subversion, JDeveloper's Team menu contains commands for using Subversion to manage the content you are working on while maintaining a connection to your team's repository and tracking changes, merges, and more. Setting up Subversion involves creating a repository for your source-controlled files, making sure that JDeveloper can connect to that repository, importing files to the repository, and more.
In general, you begin by importing your working files into the Subversion repository to bring them under version control.Once in the repository, your files are then available to be checked out from the Subversion repository to a local folder known as the "Subversion working copy." When you create a new file in JDeveloper (or move it into JDeveloper), you store it in the Subversion working copy. When you are ready to make your work available to the team, you add these new files to Subversion control. When it comes time to make your changed and new files available to other users, you can do so by committing them to the Subversion repository. To take advantage of the work others on your team have done, you can copy changed files from the Subversion repository to your working copy by updating your files.
After completing setup, your work with Subversion will revolve around checking files out, editing them in JDeveloper, and checking them in with your changes. You may also need to resolve conflicts between changes you made and those made by others in your team. Files may also be moved in and out of Subversion control, and finally, you might use special properties of the files associated with specific versions for tracking bugs, customer requests, and other characteristics.
In addition to creating a repository for your source-controlled files, making sure that JDeveloper can connect to that repository, and importing files to the repository, it may be necessary to install Subversion client software under the following circumstances:
You wish to create a local Subversion repository using the JDeveloper Subversion VCS extension.
You wish to use a Java binding (helper library) other than SVNKit, which is the one supplied with the extension.
You wish to connect to a Subversion repository through a proxy server
In all of the above cases, you will need to install separate Subversion client software. If you wish to use an alternate Java binding, you will additionally have to install the binding software.
To install Subversion client software:
svn-1.7.8-setup.exe
) from http://subversion.apache.org/
(to, for example, c:\downloads
).c:\subversion
. Reboot your computer.This procedure assumes that the operating system is Windows. For non-Windows environments, consult the documentation for the operating system package management system to ensure the vendor-supplied Subversion client contains JavaHL.
To check the installation so far, open a command prompt and type svn help. You should see a list of subcommands. If not, check that the system path contains the bin directory of the location where the client software was installed (in this example, c:\subversion\bin
).
Once you have completed installing the Subversion client software, you can check the Subversion Client installation.
Important: If you subsequently accept an update of the JDeveloper Subversion extension from the Update Center (Official Oracle Extensions and Updates), the client preference will be reset to SVNKit, even if you had previously chosen an alternate client.
To check the installation:
Before you can work with a Subversion repository through JDeveloper, you must create a connection to it. You can subsequently edit the connection details if they change for any reason.
Typically, you will obtain the details of your Subversion connection (server name, user ID, password, etc.) from your team or version control administrator. You will need to know those details before you create a connection to your Subversion repository.
To create a Subversion connection:
If any of the details (such as IP address, port, user ID, password, etc.) of your Subversion connection change, you can edit the connection in JDeveloper so that you can connect to it with the new details.
To edit a Subversion Connection:
You can export the details of your Subversion repository connections to a file. You can subsequently import the connection details from the file to recreate the Subversion repository connections. This can greatly simplify the process of connecting to a Subversion repository as new team members join, as the repository connection file can be stored on a server accessible to the team, then downloaded as required as new members join. Similarly, if new servers are added, the team leader or administrator can distribute new connection information in a connection detail file to be imported by all team members.
To export Subversion connection details to a file:
If you or your team have saved the details of your Subversion repository connection, you can import them into JDeveloper to simplify making the connection to your repository.
To import Subversion connection details from a file:
If you want to connect to a Subversion repository through a proxy server, you must first install separate Subversion client software.
Once you have installed the Subversion client software, you will have a Subversion subdirectory in your Windows Application Data directory. To find the Application Data directory, at the c:/
prompt type cd %APPDATA%
. Then open the Subversion subdirectory. (On Linux, the equivalent subdirectory will be in ~/.subversion
, where ~ is the home directory.)
Note:
If you have entered the proxy settings in the JDeveloper Preferences, you can omit editing the servers file as described in the following paragraphs.
In the Subversion subdirectory will be a file named servers
. Open this file with a text editor and find the [global] section. Remove the comment marker (#) from the line http-proxy-host
and overtype the placeholder proxy information with the details of the proxy server that you use. Remove the comment marker (#) from the line http-proxy-port
and overtype the placeholder port information with the port number for the proxy server. If you wish to exclude certain URLs from using the proxy server, remove the comment marker (#) from the line http-proxy-exceptions
and overtype the placeholder URLs with URLs that you wish to exclude.
Add additional http-proxy-host
and http-proxy-port
lines with details of any other proxy servers that you use.
It is important that the proxy server supports all the http
methods used by Subversion. Some proxy servers do not support the following methods by default: PROPFIND, REPORT, MERGE, MKACTIVITY, CHECKOUT. If you experience problems with using a proxy server to access a Subversion repository, ask the server's system administrator to change the configuration to support these http
methods.
You can export copies of JDeveloper files that are under Subversion control from either of two places: the Applications window, in which case the files will be exported from the Subversion “working copy", or the Subversion Navigator, in which case the files will be exported from the Subversion repository. Exporting the files means copying them to a local file system directory that you specify.
To export files from the Applications window:
This exports the selected files from the Subversion "working copy" of your local file system.
You can export copies of files under Subversion control from the Subversion Navigator. This ensures that the files will be exported from the Subversion repository (not from the "working copy"). In addition, exporting with the Subversion Navigator lets you specify which revision of the files to export.
To export files from the Subversion Navigator:
This exports the selected files from the repository to your local file system.
Git is a popular open-source version control system with a growing user community. To begin using Git with JDeveloper, you create a clone of your team's repository on your local system.
To complete this procedure, you will need the following information, which should be available from the Git administrator on your team:
The name of the repository
The URL at which the repository is stored
The user name and password you will use for accessing the repository. Optionally, your team may use a private key file with a passphrase; you can select the appropriate option for your team when you connect to Git.
The name of the remote branch that your team uses for development.
The destination pathname in your local system to which you wish to store your local repository.
To connect to Git:
JDeveloper connects you to the remote repository and creates a local clone based on the branch you selected. From this local clone you can check out, edit, merge, and commit files to the main repository.
In general, CVS uses a common repository of files, accessible to JDeveloper, that you and your team share while developing a software project. To modify files in that repository, you first check them out so that CVS tracks the who, when, and what of file access. In the event that two team members edit the same file at the same time, CVS contains tools that help you determine whether those changes conflict, and to resolve problems that may arise and merge these simultaneous changes into a single, comprehensive file. Finally, CVS lets you check these changed files back into the repository so that your build tools will have access to the latest files, with new and/or merged content.
Note:
For extensive information about how to use and administer CVS, see the CVS online manual at http://www.cvshome.org
.
Before you can use CVS to manage your shared content, you need to connect JDeveloper to CVS. This means configuring JDeveloper, making a connection to your team's CVS repository, creating a local repository, and more. The topics in this section cover all the steps you'll need to make sure CVS is available from JDeveloper after downloading the CVS extension from Check For Updates. If your team is already using CVS, you should check with them for specifics on how CVS is implemented in your organization.
The process of setting up CVS with JDeveloper involves configuring JDeveloper, creating a CVS connection, importing files for the project into your CVS repository, and then checking out the CVS modules to be edited.
Before you can use CVS, you need to configure JDeveloper by setting preferences.
To configure JDeveloper for use with CVS:
Once you have installed the CVS extension in JDeveloper, you must create a connection to CVS before you can access the repository.
To create a CVS connection:
If any of the connection details change after creation, you can edit the CVS connection.
To edit a CVS connection:
You use the CVS Export wizard to export the revisions of files for a module, creating a deployment-ready file structure.
To use the CVS Export wizard:
The files are exported to the location you have specified.
You can copy the path of the CVSROOT from a node in the CVS Navigator to the Clipboard, for use in other applications.
To copy the CVSROOT path to the Clipboard:
The full path of the CVSROOT is copied to the Clipboard, from where you can paste it into another application.
In addition to a local CVS repository for storing files as you are working on them, configure secure shell for communication with CVS, select a character set, and log in to CVS.
In addition to setting up JDeveloper to be able to use CVS, there are certain tasks you need to perform to make CVS usable with JDeveloper. Some of these tasks may be performed by your administrator. You should always check to make sure which of these tasks have been performed in your installation.
In general, you need a local CVS repository for storing files as you are working on them. You may also need to configure a secure shell (SSH) for communicating with CVS, and you may need to choose a character set. Finally, you will need to log in to CVS.
Every CVS repository connection needs a character set to encode files, the default being the set specified by the platform or operating system which can be changed using the Set Encoding dialog. Use the procedure to select a character set.
If your installation uses a local CVS client, you need to choose a character set.
For each CVS repository connection, you can choose the character set to be used for the encoding of files. The default is to use the character set specified by the platform/operating system.
You can change to the IDE default or to a specific character set through the Set Encoding dialog.
To choose a character set:
JDeveloper requires that the Perforce extension and Perforce features be installed for it to work with Perforce. JDeveloper must be configured to connect to the Perforce client workspace, and working files must be brought under Perforce control.
Before using Perforce with JDeveloper, in addition to downloading the Perforce extension, you need to install a number of Perforce features so that they are available to JDeveloper. Once installed, you configure JDeveloper and connect to the Perforce client workspace. Finally, you need to bring your working files under Perforce control so that they are available from within JDeveloper while using Perforce.
There must be at least one Perforce server installed, on a machine that is accessible to the intended JDeveloper users. If a Perforce server installation does not already exist, obtain the necessary software (for example, from www.perforce.com) and install it in accordance with Perforce's instructions. Record the identity of the machine on which the Perforce server software has been installed: you will need this when you connect to it through JDeveloper.
Before using Perforce with JDeveloper, in addition to downloading the Perforce extension, you need to install a number of Perforce features so that they are available to JDeveloper. Once installed, you configure JDeveloper and connect to the Perforce client workspace. Finally, you need to bring your working files under Perforce control so that they are available from within JDeveloper while using Perforce.
For JDeveloper to work with Perforce, at least one Perforce server must be installed on a machine that is accessible to JDeveloper users.
There must be at least one Perforce server installed, on a machine that is accessible to the intended JDeveloper users. If a Perforce server installation does not already exist, obtain the necessary software (for example, from www.perforce.com) and install it in accordance with Perforce's instructions.
The Perforce client application and the Command Line Client must be installed on the same computer as JDeveloper. Create a Perforce client workspace which stores working copies of files under Perforce control.
You must install the Perforce client application on the machines that contain (or that will contain) JDeveloper. The Perforce client application can be installed from the same software as the server software, obtainable from www.perforce.com. The installation must include the “Command Line Client (P4)".
When you first run the Perforce client application, you will be required to create a Perforce client workspace. The Perforce client workspace is where the working copies of files under Perforce control will be stored. You can use the JDeveloper default directory as the Perforce client workspace, whether or not it already contains JDeveloper files. The JDeveloper default directory is <installation_directory>\jdev\mywork
. Alternatively, you can accept the default Perforce client workspace, or specify one of your own. In these cases, you should note the location you have used, because you will need to specify it when creating applications and projects in JDeveloper.
If you set up passwords in the Perforce client application, you will also need to use them when connecting to Perforce through JDeveloper.
Install JDeveloper on every computer that must function as a Perforce client. JDeveloper functions as a client application for Perforce.
JDeveloper must be installed in the normal way. Each installation of JDeveloper can act as a client application for Perforce. You can install JDeveloper on every machine that you wish to be a Perforce client, or you can use a mixture of JDeveloper installations and Perforce's own client applications. The JDeveloper and Perforce client applications will work together in a seamless manner. In addition to the JDeveloper embedded support for Perforce, you will also be able to access a Perforce client application through the JDeveloper interface.
Install the Perforce server and client software, and configure JDeveloper to use Perforce. Use the procedure to configure JDeveloper for use with Perforce.
Before you can configure JDeveloper to use Perforce, you must have installed the Perforce server and client software.
To configure JDeveloper for use with Perforce:
After configuring JDeveloper for use with Perforce, specify Perforce as the version control system so that all team operations default to Perforce. Select the Perforce option available on the Team menu to specify Perforce as the version system.
Once you have configured JDeveloper for use with Perforce, you can select Perforce as the version system. This will specify a number of default settings which mean that all team operations will default to Perforce as your chosen version system.
To select Perforce as the version system:
Choose Team > Perforce.
You can change this default selection at any time if your team changes to a different version system at a later date.
Use the source control features of Microsoft Visual Team System within JDeveloper with the Oracle JDeveloper Team System extension. Use the steps to set up the team system client software and configure JDeveloper.
Oracle JDeveloper's Team System extension allows you to use the source control features of Microsoft Visual Team System inside JDeveloper. Once you have JDeveloper configured to work with Team System, you can add files to source control, and check them in and out from the Applications windows.
To begin using Team System with JDeveloper, you must first create a workspace using Team System software, and then populate this workspace with content from the Team System server. Files are checked out to the workspace, where they can be worked on. Files newly created within JDeveloper must be added to version control. Changed and new files are made available to other users by checking them in to the Team System server.
Before beginning to use Team System with JDeveloper, there are some initial steps you need to follow:
Set up the Team System client software. See Setting Up Team System for Use with JDeveloper.
Configure JDeveloper for use with Team System, including the preferences and other settings for making Team System the source control system recognized by JDeveloper. See Configuring JDeveloper for Use with Team System.
In practice, Team System (like any version control system) consists of operations that you use at varying times depending on the place in the product lifecycle. For example, if you create a new file, you'll need to add it to Team System control. Other operations you may perform, depending on the stage of development, include:
Checking out files from the server so that you can work on them. See Checking Out Files in Team System.
Making changes to a file saved in your Team System workspace, and make them available to other users. See How to Check In Files to Team System.
Using Team System's Shelving feature to save file changes in the Team System server without having to check the files in. See Shelving and Unshelving Team System Files.
Resolving conflicts between your changes and changes made by your team mates to your Team System files
Checking in files to your Team System server.
Install the software, connect to the server, and populate the workspace to use Team System with JDeveloper. Use the procedure to set up Team System with JDeveloper.
Using Team System with JDeveloper requires a setup procedure that includes installing software, connecting to your server, and populating your workspace.
To set up Team System with JDeveloper:
Instructions for doing the above are given in the Team System online help.
Install JDeveloper Team System VCS extension and configure JDeveloper. Use the steps to configure JDeveloper for use with Team System
Once you have set up Team System for use with Oracle JDeveloper, you are ready to configure JDeveloper to use Team System. In addition to the steps in Setting Up Team System for Use with , make sure you have already installed the JDeveloper Team System VCS extension (from the Official Oracle Extensions and Updates center).
To configure JDeveloper for use with Team System, carry out the following activities in JDeveloper:
Connect to Team System as the JDeveloper versioning system.
Set the workspace to use with JDeveloper.
Create a JDeveloper project to hold the workspace files.
Refresh the workspace folders in JDeveloper.
Connecting to Team System ensures that it becomes the target for tasks from the Team menu. Use Connect to Team System available on the Team menu to connect to Team System.
Connecting to Team System as the default versioning system specifies that Team System is the target for a number of actions from the Team menu.
To connect Team System as the versioning system:
Choose Team > Connect to Team System.
This displays the Team System connection menu, from which you can select the available operations. Detailed instructions for this are given in the Team System online help.
Set up the selected Team System workspace to use JDeveloper. Use the procedure to set the workspace to use with JDeveloper.
Before beginning, you need to set your selected Team System workspace to use JDeveloper.
To set the workspace to use with JDeveloper:
When you create and edit files, the JDeveloper project and the selected Team System workspace association keeps the work in the team workspace. Use the procedure to create a JDeveloper project to hold the workspace files.
Associating the JDeveloper project with the selected Team System workspace ensures that the files you create and edit will remain part of the workspace your team is using.
To create a JDeveloper project to hold the workspace files:
Once completed, refresh the workspace folders in JDeveloper by choosing Team > Refresh Workspace Folders.
From the Team System server, you can get different versions of files. Use the procedure to get versions of files from the Team System server.
JDeveloper lets you get (from the Team System server) a version of a file that is in the Applications window. You must previously have used the get command in the Team System client software to populate your workspace with source files.
You can use this procedure to obtain the following versions of files: the latest version; files from a previously saved named changelist; files with a particular date stamp; files from a previously created named label; files from a particular workspace version.
The version obtained from the Team System server will replace the version currently in the Applications window.
To get versions of files from the Team System server:
When files are brought under Team System source control, the files are added to the Team System server and made available to other users when they are checked in. Use the procedure to add files to Team System Control.
You can bring files under Team System source control. The files will be added to the Team System server and made available to other users when you next check in the file.
To add files to Team System Control:
Mercurial is a Source Control Management system that works with distributed repositories. Mercurial commands can be run on both files and directories in the Projects, Files and Favorites windows.
Mercurial is a Source Control Management system designed for efficient handling of very large distributed projects. Unlike Subversion, Mercurial works with distributed repositories which are commonly used in many open source projects today and support distributed development without any centralized control.The Mercurial Plugin support enables you to manage changes to version-controlled files as you work. You can call Mercurial commands on both files and directories in the Projects, Files and Favorites windows.
The advantages of a distributed revision control system like Mercurial include:
Better support for distributed teams by removing a centralized bottleneck
Better scalability with large numbers of concurrent users
After the initial clone, faster to work with, independent of a user's network infrastructure
JDeveloper provides several file status information tools, such as Color Coding and Annotations, to simplify the process of working with version-controlled files.
JDeveloper provides several file status information tools that simplify the process of working with version-controlled files, including:
Color Coding. Enables you to view the current status of version-controlled files.
Annotations. Enables you to view revision and author information for each line of version-controlled files.
JDeveloper's Mercurial support is similar in style to its Subversion support. The main difference is that Mercurial is a distributed revision control system. Therefore, you typically begin by cloning an external repository to work with. This clone is a complete copy of the repository including the revision history. You can clone this local copy as often as you like. When you want, you can push your changes back to the original repository provided you have permissions, or export your changes and send them to the owner if you do not.
For further documentation on the Mercurial Plugin support and Mercurial itself, see the following resources:
Mercurial Home: http://mercurial.selenic.com/wiki/
Understanding Mercurial: http://mercurial.selenic.com/wiki/UnderstandingMercurial
Mercurial Man Pages: http://www.selenic.com/mercurial/wiki/index.cgi/ManPages
Install Mercurial client software using the JDeveloper Check for Updates feature, and then run Mercurial commands from the Mercurial option available in the Team menu. Use the procedure to install Mercurial.
Before you can take advantage of the Mercurial support, you need to have Mercurial client software installed on your system. JDeveloper's Mercurial support works by using the same commands as the Mercurial command line interface.
Mercurial is available through JDeveloper's Check for Updates feature. After you set up Mercurial, you can run Mercurial commands from the Team > Mercurial menu at the top of the JDeveloper main window.
To install Mercurial:
Select Help from the main JDeveloper window, then Check for Updates.
On the first page of the Select Update Source wizard, make sure Search Update Centers is selected.
Select Official Oracle Extensions and Updates.
Click Next.
The wizard updates with a list of extensions you can install.
On the Select Updates to Install page of the wizard, select the checkbox next to Mercurial VCS Extension.
Click Next, then Finish.
The Mercurial extension installs. Installation is complete after you restart JDeveloper.
You can also access the Check for Updates wizard by selecting Tools > Features > Check for Updates. For more information, see Working with Extensions.
After the Mercurial client is set up, you can run Mercurial commands from the main window by selecting Team > Mercurial.
If the hg.exe
file for Mercurial is not on the system path, then set the path to the file. Use the procedure to set the path to the Mercurial executable file.
After installing through Check for Updates, you may set the path to the hg.exe executable file. hg.exe is the executable file for Mercurial. You only need to set the executable file if is not on the system path.
To set the path to the Mercurial executable file:
On the main JDeveloper window, select Tools >Preferences.
In the left pane of the Preferences dialog, expand Versioning, then click on Mercurial.
On the Versioning: Mercurial page you can select:
The name of the executable that will be used to run Mercurial, for example, hg.exe.
One of the installations of hg.exe in the system or different revisions of it, if they exist.
Some other location of hg.exe if, for example, it isn't on the system path.
Cloning a Mercurial repository creates a copy of the entire repository to work with in JDeveloper. Use the procedure to clone a Mercurial repository.
A repository is a directory that contains source files, along with their complete histories. Cloning makes a complete copy of another repository so that you have a local, private version of it to work with. You can create a local repository in any directory where you have write permission.
When cloning, you effectively create a copy or clone of the entire repository to work with in the IDE. To do so, you need to be able to access a Mercurial repository that you have read privileges for.
To clone a Mercurial repository:
On the main JDeveloper window, select Team > Mercurial > Clone.
On the Clone Repository window, enter the Source Location of the repository.
This is the location of the repository that is to be cloned. You can enter either a URL or local path, for example, http://selenic.com/hg
.
In the Destination field, enter a destination for the local repository, for example, C:/JDeveloper/mywork/hg1
.
Enter a User Name and Password for the remote repository, if required.
Click OK.
Placing a project under version control creates a new local Mercurial repository in the current directory and imports sources into it. Use the procedure to place a project under version control.
You can place any project you are working on under version control. This creates a new local Mercurial repository in the current directory and imports your sources into it. The repository files are placed under a .hg
directory under the project directory.
To place a project under version control:
In the Projects window (located on the left side of JDeveloper), select an unversioned project.
From the JDeveloper main window, select Team > Mercurial > Initialize.
You can view files being added to the repository and their status from the Messages Log window.
Once complete, all the project files are registered in the repository as Locally New.
Select Mercurial > Commit from the project's context menu to commit these project files to the Mercurial repository.
Enter a message about the change being committed in the Commit Message text area, and then click Commit.
The committed files are placed together with the .hg
directory in the Mercurial repository directory.
When you merge changes between repository revisions and the local working copy, the working copy is updated with all the changes that were made. Use the procedure to merge file revisions.
You can merge changes between repository revisions and your local working copy. The current working directory is updated with all changes made to the requested revision since the last revision.
To merge file revisions:
From the JDeveloper main window, select Team > Mercurial > Initialize.
In the Working Directory field of the Merge Working Directory dialog, enter the top-level directory in the repository, for example, c:\JDeveloper\mywork\hg1
.
Check the Use Revision checkbox and enter the revision number.
If you don't know the number for the revision, click Select Revision. A dialog displays the available revisions number listed from most recent, the revision date, the user who made the revision, and comments.
If working copies of version-controlled files have been edited, the Mercurial Commit action places the changes in the repository. Use the procedure to commit changes in local files to the repository.
Once your working copies of version-controlled files have been edited, you can then place changes into the repository using the Mercurial Commit action.
It's a good idea to update any copies you have against the repository prior to performing a commit in order to ensure that conflicts do not arise. This updates the local repository to include the latest changes.
To perform an update on sources that you have modified:
In the JDeveloper main window, select Team > Mercurial > Update.
To commit changes in local files to the repository:
Select a version-controlled file (for example, from the Projects window) and right-click.
Select Versioning > Commit from the context menu.
The Commit Dialog opens, listing all files that contain local changes.
Enter a commit message in the Commit Message text area, indicating the purpose of the commit.
You can also select either a comment template you created in Tools > Preferences > Versioning > Templates or one of the comments that you have previously entered in the Commit dialog.
Click OK.
JDeveloper executes the commit and sends your local changes to the repository. You can view files being committed to the repository in the Messages log.
Use Commit All to view all the changed files that you can commit to the Mercurial repository. You can commit selected files or all outstanding changes. Use the Shift
or Ctrl
keys to select which files you want to commit.
Configure the source repository after you have initialized the version control system in JDeveloper. Load the repository with content before you use Subversion with JDeveloper.
After initializing your version control system in JDeveloper, the next important step is to configure the source repository. Typically, you maintain a local repository, containing local copies of the files you are working with, on your own system. You typically check out the files you want to work on, make edits to the versions on your local system, and then check the files back in to the remote repository. Your version control system typically tracks, or at least notifies you of, changes and conflicts if more than one person is editing a file at a time. The menu options and details vary from system to system; these variations are described individually in each of the following sections.
Before beginning to use Subversion with JDeveloper, you will need to load your repository with content so that you have local versions to edit. For more information, see How to Load the Repository with Content.
For every project or release, a repository has to be created. The source repository is used to check out and check in files.
Creating a repository is something you typically only do once per project/release; once you have created the repository, you check files in and out as part of your daily work routine. In many teams, the source repository is created by a team member assigned to the role of administrator for the repository; if this is the case, you may be able to skip this section and rely instead on accessing the existing source repository for checking out and checking in files.
The details of creating and connecting to your source repository differ depending on the versioning software your team uses. The following sections include instructions on creating source repositories for the versioning systems available to JDeveloper.
A Subversion repository may need to be created on the local file system through JDeveloper which will access the repository using the file:///
protocol. Use the procedure to create a Subversion Repository.
In most cases, you will connect to your team's Subversion repository. As you develop your projects and applications, you will check files out from the Subversion repository, modify them, and check them back in. This is the typical, and recommended, practice for using Subversion.
Depending on your installation, however, you may find it necessary to create a Subversion repository on your local file system through JDeveloper. A connection to the repository will be created at the same time.
JDeveloper will try to use the file:///
protocol to access the newly created repository. SVNKit, the Subversion client installed with JDeveloper, supports the file:///
protocol. If you are using a Subversion client that does not support the file:///
protocol, you will need to use a different access method (http://
, https://
, svn://
or svn+ssh://
). Consult the Subversion documentation for how to do this.
To create a Subversion Repository:
Choose Team > Create Local Repository.
If your installation does not support local repository creation, you will see an error message. Otherwise, the Create Subversion Repository dialog will open.
Complete the Create Subversion Repository dialog.
To obtain help while using the dialog, press F1 or click Help.
To browse a Subversion Repository:
A new project with all new files requires a Git repository initialization. Initialization is done once for a project, at the beginning of the project. Use the procedure to initialize a Git repository.
If you have new files that are not already part of any existing Git repository, you need to initialize a Git repository.
You initialize a Git repository when you have a new project with all new files. This is typically done once per project, at the beginning. As an ongoing task, you are more likely to add new files to an existing Git repository (see Adding New Files to an Existing Git Repository), or check out files, edit them, and then commit the changes back to the Git repository (see Committing a Change to the Git Repository).
To initialize a Git repository:
Use Git, HTTP, HTTPS, or Secure Shell protocol to make a local copy of a central Git repository. Use the step to clone a Git repository.
If your team already has a central Git repository and you wish to make a local copy of it for your work, you can clone the Git repository as described here.
The following protocols can be used to clone Git repositories:
Git (git://
). The simplest way of connecting to the Git server. The connection is not authenticated.
HTTP (http://
). HTTP is another simple way of connecting to the server. http:// connections are insecure even with authentication as the files will be transferred in clear.
HTTPS (https://
). Connects to the server using password authentication. https:// connections are fully secure and will work through a web proxy.
Secure Shell (ssh://
). This uses public key authentication, and you will need to generate an authentication key using a utility such as ssh-keygen
. This is the most secure way of cloning an existing Git Repository. However, it will require additional setup if you are trying to connect through a web proxy.
To clone a Git repository:
Select Team > Git > Clone.
This opens the Clone from Git Wizard. Enter the information requested on each screen. You can press F1 or click Help at any time for more information.
To add new files to an existing Git repository, select, add the files, and then commit them. Use the procedure to add new files to an existing Git repository.
Adding new files to an existing Git repository involves selecting, then adding the files, and finally committing them for the changes to be incorporated into the repository.
To add new files to an existing Git repository:
If external CVS client software is in use, you can create a new CVS repository on a local file system. Use the procedure to create a local CVS repository.
From within JDeveloper, you can create a new CVS repository on your local file system. This feature is available only if you are using external CVS client software, rather than the internal CVS client installed as part of the CVS extension to JDeveloper.
To create a local CVS repository:
To use a JDeveloper project with CVS, import the project files into the CVS repository so that they are placed under source control. Use the procedure to use the Import to CVS wizard.
Before you can start using your JDeveloper project with CVS, you have to import the project files into the CVS repository. This copies all your folders and files to the CVS repository and places them under source control.
You import your project files into the CVS repository using the Import to CVS wizard.
To use the Import to CVS wizard:
Before you can change any files, you have to copy them back to your machine, where you can work on them locally.
Files to be brought under source control are placed in the Perforce client workspace, and then submitted to a central location called the Perforce depot to version them and make them accessible to users. Use the procedures to place JDeveloper files and files created outside JDeveloper under Perforce control.
Perforce uses a local directory structure to receive files that are going to be placed under formal source control. This location is called the “Perforce client workspace". Files created in (or moved into) JDeveloper must be stored in this location. Once files are in your Perforce client workspace, you bring them fully under source control by submitting them to a central location called the “Perforce depot". Files must be submitted to the Perforce depot before they can be versioned and accessed by other users.
Files that you create within JDeveloper, or files that you bring into JDeveloper from outside, must be brought under Perforce control before you can use the JDeveloper Perforce versioning facilities with them.
If you have an existing JDeveloper project that you wish to bring under Perforce control, use the Import to Perforce wizard.
To put individual JDeveloper files under Perforce control:
Select the files in the Applications window and choose Team > Perforce > Open for Add.
The files can be your work files, or they can be the application and project files used by JDeveloper.
The Add Files to Perforce dialog is displayed with the files listed.
If you wish to lock the files, making them unavailable to others for editing, check the Lock Files box.
To add the files to Perforce control, click OK.
The files are now shown in the Applications window with a red cross, meaning that they are stored in your Perforce client workspace but not yet in the Perforce depot. Files must be added to the Perforce depot before they can be versioned and accessed by other users.
To add files to the Perforce depot, select the files in the Applications window and choose Team > Perforce > Submit.
The Submit Files dialog is displayed with the files listed.
Add your versioning comments in the Comments box.
You will later be able to see these comments when viewing the list of versions of a particular file.
To submit the files to the Perforce depot, click OK.
The files are now shown in the Applications window with a green dot, indicating that they are known to the Perforce depot and are up to date.
To bring files created outside JDeveloper under Perforce control:
Use the Connect To... option in the Team menu to connect to a source control repository that has been created.
Once the source control repository has been created (either by you or by a team administrator), you typically connect to it from the Team menu, then selecting your versioning system from the Connect To... option.
The current content of the Subversion repository can be viewed by means of the Versions window. The folders offer the New, New Remote Directory, Delete, and Check Out options.
You can view the current content of the Subversion repository through the Versions window. The nodes under your selected Subversion connection unfold to reveal the structure and file content of the Subversion repository.
You can open a read-only version of a Subversion repository file by choosing Open from its context menu. This will let you see what changes have been made to the files in the Subversion repository since you checked out or updated your local versions.
Folders in the Subversion repository, visible from the Versions window, offer the following operations:
Opens the new gallery, from which you can create applications, connections, projects, and other entities.
Opens the Create Directory dialog, which lets you create a new directory to associate with the URL of the element on which you right-clicked.
Removes the selected element immediately from the JDeveloper view, without a confirmation dialog. Use with caution.
By default, opens the Check Out from Subversion dialog.
If you have configured JDeveloper for a different version control system, Check Out will open the checkout dialog for your selected version control software.
Independent of making connections, some types of connection to a CVS repository require logins. Use the procedure to log in to a CVS repository.
Some types of connection to a CVS repository require you to log in independently of making the connection. If you cannot access any CVS features even though a CVS connection exists, you need to log in.
To log in to a CVS repository:
The path that JDeveloper uses to a CVS client on a computer will set the JDeveloper CVS preferences, and to use that CVS client by default, and if no path is found, preferences will need to be set to use the internal CVS client. Use the given step to access CVS through a firewall.
If JDeveloper finds a path to a CVS client on your machine, the JDeveloper CVS preferences will by default be set to use that CVS client (rather than the internal CVS client installed with JDeveloper). If no path to a CVS client is found, the preferences will be set to use the internal CVS client.
The internal CVS client cannot be used to access a local CVS repository (that is, one on your own machine). If you wish to access a local CVS repository, you must install a full client/server version of CVS onto your machine and set the JDeveloper CVS preferences accordingly.
If you wish to use an external CVS client, we recommend the following:
CVSNT 2.0.58a or higher for Windows platforms - http://march-hare.com/cvspro/
cvshome's CVS 1.11.9 for other platforms
Note:
You may already have a CVS installation that is client-only. This will not be able to access a local CVS repository, and you should install a full client/server version instead. If you are unable to expand the connections node in the CVS Navigator or open the list of modules from the Get Module List button in the CVS wizards, you probably have client-only CVS software that is attempting to access a local CVS repository. You can check which type of CVS installation you have by typing cvs -v
at the CVS command prompt. A client-only installation will display (client) at the end of the version information line, whereas a client/server installation will display (client/server).
To access CVS through a firewall:
If you are accessing a CVS server through a firewall, you can connect to it if:
The firewall allows TCP/IP communication on the CVS port
You use a CVS client that supports HTTP Tunneling (for example, CVSNT)
If there is an authentication failure when you log in, try using the CVS command line to connect. If this fails, the connection may be being blocked by the firewall, and you should contact your network administrator.
If necessary, you can alter the value of the CVS root variable to support connection through a firewall.
For the automatic handling of binary files produced by JDeveloper, the CVS repository has to be configured by a CVS administrator.
The CVS administrator has to configure the CVS repository for the automatic handling of binary files produced by JDeveloper, such as image file formats.
Where other file types are updated, CVS attempts to merge them. If you do not want is to occur, you must change the configuration of the CVS repository.
For more information about CVS, refer to the CVS documentation, or see the CVS website, http://www.cvshome.org
. This is also where you can download CVS software.
Connect Perforce to JDeveloper so that its operations become available within JDeveloper. Use the procedure to connect to Perforce manually.
Before Perforce operations become available within JDeveloper, you must connect to it.
To connect to Perforce manually:
Multiple connections can be made to Perforce for work such as development and testing. Use the procedure to create a named Perforce connection.
In some development environments, you may need to make more than one connection to Perforce. For example:
Your organization uses one Perforce server for development and another Perforce server for test.
You wish to connect using two different Perforce clients.
You wish to use different Perforce user IDs.
The Perforce extension to JDeveloper permits all these operations. You begin by giving each Perforce connection a name as you create it.
To create a named Perforce connection:
Note that your Perforce changelist will display the connection that applies to each file in the changelist. For more information on changelists, see How to Use Change Sets and Changelists.
Subversion requires no JDeveloper configuration for the source repository. Other version control systems have configuration requirements.
If you are using Subversion, which is included by default in JDeveloper, you do not need to configure JDeveloper for your source repository. You only need to connect to the repository, then you update your local working copy, check files out to work on them, and then check in your changed files on completion. Other version control systems, however, have configuration requirements, which require you to configure them, and JDeveloper, before use.
Set up JDeveloper to use CVS, create a local CVS repository for storing files, configure a secure shell for communicating with CVS, select a character set, and log into CVS.
In addition to setting up JDeveloper to be able to use CVS, there are certain tasks you need to perform to make CVS usable with JDeveloper. Some of these tasks may be performed by your administrator. You should always check to make sure which of these tasks have been performed in your installation.
In general, you need a local CVS repository for storing files as you are working on them. You may also need to configure a secure shell (SSH) for communicating with CVS, and you may need to choose a character set. Finally, you will need to log in to CVS.
JDeveloper supports SSH Levels 1 and 2 as access methods for CVS repositories.
Configure SSH Level 1 so that it can be used for remote shell access. Use the procedure to configure SSH Level 1 to enable remote shell access.
JDeveloper does not provide a direct way of using SSH Level 1 as an access method for the CVS repository. It is however possible to configure SSH Level 1 so that it can be used for remote shell access.
To configure SSH Level 1 to enable remote shell access:
Generate public and private keys using the command: ssh-keygen
Concatenate the ~/.ssh/identity.pub
public key file with ~/.ssh/authorized_keys
on the machine with the CVS repository.
Before running JDeveloper and attempting to use CVS with SSH Level 1, users should be explicitly authorized and the environment correctly configured. Follow the steps below to configure the environment correctly.
To configure the environment for SSH Level 1:
CVS_RSH
environment variable to the location of the SSH client.ssh-agent {shell}
, and then press Enter.ssh-add
, and then press Enter.Use SSH2 as an access method for the CVS repository in JDeveloper. Use the procedure to use SSH2 for remote shell access.
JDeveloper provides a direct way of using SSH2 as an access method for the CVS repository.
To use SSH2 for remote shell access:
If you are using an internal CVS client, you can generate SSH2 key files at any time by choosing Team > CVS > Administration > Generate SSH2 Key Pair. If you are using an external CVS client, this menu option is unavailable.
When an external CVS client executable is used, both editing and watching become available. Use the procedures to set up JDeveloper to use editing and watching, and release an editor on a file.
Editing and watching are available only when an external CVS client executable is used.
These procedures allow you to obtain and release an editor on a file, to know who else in your team is editing files, and to know who is watching for files to be edited. Two or more developers retain the ability to edit the same file at the same time.
To set up JDeveloper to use editing and watching:
Open the preferences page obtainable from Tools > Preferences | Versioning | CVS.
Ensure that External Executable is selected and that valid details are entered.
Select Run CVS in Edit/Watch Mode.
Open the preferences page obtainable from Tools > Preferences | Versioning | CVS | General.
Deselect Automatically Make Files Editable.
To obtain an editor on a file:
With the file selected in the Applications window, select Team > Edit.
Check that you want the operation to apply to all of the files highlighted in the file selection box.
To set up a watch for this file, select the Set Watch Actions checkbox and select a watch action from the drop-down list.
Click OK.
To release an editor on a file (to unedit a file):
This action reverses changes made in the current edit. Any local file modifications will be lost when the editor is released.
With the file selected in the Applications window, select Team > Unedit.
Check that you want the operation to apply to all of the files highlighted in the file selection box.
Click OK.
To turn on or turn off the file watching facility:
In the Applications window, select a project containing files about which you want to be notified.
Select Team > Watch.
In the Watch CVS Files dialog, choose Turn On Watching or Turn Off Watching from the Command Type drop-down list.
Click OK.
To add yourself to the list of people who receive notification of work done on files:
To remove yourself from the list of people that receive notification of work done on files:
Follow the procedure for adding yourself to the list (above), but choose Remove File Watch from the Command Type dropdown list.
To see who is watching for changes being made to files:
Select Team > Edit Notifications.
The Edit Notifications window is opened. The Watchers tab shows the files that are being watched and the user(s) who are currently watching for changes.
To see who is currently editing files:
Select Team > Edit Notifications.
The Edit Notifications window is opened. The Editors tab shows the files that currently have editors on them and the user(s) who have obtained those editors.
Load the repository with content for the team to use the repository for the selected version control system.
Before you can use the repository for your selected version control system, you typically have to load the repository with the content your team will be working on. You might need to do this when:
Your team begins to work on a new version of the project (especially if you are working on more than one version concurrently, such as a patch set and a major update)
Your team is starting an all-new project, either by beginning with an older version or with file templates
You are performing a clean installation of JDeveloper on a new workstation that does not yet contain a local file system to store your repository's files as you work on them
Normally, loading the repository with content is done once per project. After this initial load, you will regularly update the files and folders in your local repository to ensure that your files are up to date with the work of your team.
Import files into the Subversion repository from JDeveloper, and then check them out. Use the procedure to import an existing JDeveloper project or application into Subversion.
Files that you created within (or brought into) JDeveloper before using Subversion control must be imported into the Subversion repository, and then checked out from it.
To import an existing JDeveloper project or application into Subversion:
Import an entire project into Subversion using the JDeveloper Version Application feature. Use the procedure to import files using Version Project.
You can also import an entire project into Subversion using the JDeveloper Version Application feature.
To import files using Version Project:
After you import files into Subversion using the Version Application feature, you will notice that Subversion creates two directories, one as your work area and one as a backup directory.
For example: after creating a new application called Catalog, select Versioning > Version Application > Subversion. Be sure to select the Perform Checkout from the Options page, then finish the wizard.
When the wizard completes, browse to the local directory that you have specified as the Source Directory for this application in Subversion. You will see two directories listed there: Catalog.svn-import-backup
and Catalog.svn-import-workarea
.
JDeveloper (and Subversion) will use the Catalog.svn-import-workarea
directory for file access, checkout/checkin, and other activities. You should avoid editing, moving, or manipulating files in those directories outside of JDeveloper and Subversion.
A new file in JDeveloper must be added, and then committed to Subversion control so that it can be used with the JDeveloper Subversion facilities. Use the procedure to add new files on commit.
When you create a new file in JDeveloper that is part of a local working copy (that is, an application that has been versioned and checked out of your SVN repository), you need to add and then commit the file to Subversion control before you can use the JDeveloper Subversion facilities with it. The preferred method is to set up JDeveloper to do this automatically, through the Preferences menu.
To add new files on commit:
Files can individually be added to Subversion. Use the procedure to place individual files under Subversion control.
You can also place individual files under Subversion control.
To place individual files under Subversion control:
When working with remote Git repositories, in addition to pull
and clone
, it may be necessary to Git fetch
content from a remote repository to bring changes into a local repository without changing any existing branches. Use the procedure to copy from a remote repository without changing existing branches.
While you use your local Git repository for changes made while editing, it is frequently necessary in a distributed team to work with remote repositories. Push, pull and clone are three concepts that apply to remote Git repositories.
Fetching and pulling are two different methods of obtaining content from a remote repository. When you fetch from a remote repository, Git loads all changes into your local repository but it does not change any of your existing branches. This way, you can inspect the changes and merge them as appropriate.
To copy from a remote repository without changing existing branches:
Pulling, on the other hand, copies files from the remote repository and updates the HEAD branch of your local repository.
To copy changes from your local repository to the remote repository, use the Push command.
To be placed under formal source control, files must be stored in the Perforce client workspace, and then placed in the Perforce depot so that they can be versioned and accessed by other users. Use the procedure to use the Import to Perforce wizard.
Perforce uses a local directory structure to receive files that are going to be placed under formal source control. This location is called the “Perforce client workspace". Files created in (or moved into) JDeveloper must be stored in this location. Once files are in your Perforce client workspace, you bring them fully under source control by submitting them to a central location called the “Perforce depot". Files must be submitted to the Perforce depot before they can be versioned and accessed by other users.
Before you can start using existing JDeveloper project and source files with Perforce, you have to import them into your Perforce client workspace. Once they are in your Perforce client workspace, you bring them fully under source control by submitting them to the Perforce depot.
You import JDeveloper project and source files into your Perforce client workspace using the Import to Perforce wizard.
To use the Import to Perforce wizard:
Update individual files or the contents of a project folder using CVS update operations, or replace local files with files from the CVS repository. Use the procedures to update an individual file, to update the contents of a project folder, and to update files shown in the Pending Changes window.
The CVS update operation updates your local files with data in the CVS repository. Alternately, you can choose to completely replace your local files with those held in the CVS repository.
You can update individual files (including project files), or you can update the entire contents of a project folder.
You can view the contents of the CVS repository through the CVS Navigator. The nodes under CVS Server unfold to reveal the structure and file content of the CVS repository. You can open a read-only version of a CVS repository file by choosing Open from its context menu. This will let you see what changes have been made to the files in the CVS repository since you checked out or last committed your local versions.
To update an individual file (including a project file):
Select the file(s) in the Applications window, and then choose Team > Update.
Set the options as required. For information about these options, press F1 or click Help.
To update all the files listed, click OK.
To update the contents of a project folder:
Select the project folder(s) in the Applications window and then, from the context menu, choose Update Project Folders.
Set the options as required. For information about these options, press F1 or click Help.
To update all the files listed, click OK.
To update files shown in the Pending Changes window:
Note:
For the Pending Changes window to be populated with candidates, the project containing those candidates must be open. If you do not see a file that you expect to see, open the project (File > Open > Project, then select your project).
Web-based Distributed Authoring and Versioning is an extension to HTTP which allows users to collaborate in editing and managing files on WebDAV-enabled servers. .JDeveloper acts as a WebDAV client to connect directly to any Oracle Internet File System allowing users to view WebDAV files from the database.
Web-based Distributed Authoring and Versioning, or WebDAV, is an extension to HTTP which allows users to edit and manage files on WebDAV-enabled servers in a collaborative fashion. WebDAV connections in JDeveloper allow you to view files hosted on WebDAV servers in the same way as you would files on the local file system. Files located on WebDAV servers, accessed using WebDAV connections in JDeveloper, can be viewed in the same way as files stored on the local file system or LAN.
As WebDAV clients provide access using HTTP, files can be accessed through firewalls (configured to support WebDAV extensions) that would otherwise prevent FTP file transfer. The JDeveloper read-only implementation of WebDAV supports the current WebDAV 1.0 standard, which does not support versioning. As a WebDAV client, JDeveloper can connect directly to any Oracle Internet File System, allowing you to view WebDAV files from the database.
Run a WebDAV server, Apache 1.3.19 or above, and conforming to the WebDAV 1.0 standard to use JDeveloper as a WebDAV client.
You must run a WebDAV server to use JDeveloper as a WebDAV client. The WebDAV server must be one of the following:
Apache 1.3.19 (or above)
Note:
If the Apache server is version 1.x, the mod_dav
module must also be installed.
A server that conforms to the WebDAV 1.0 standard
Note:
If you access the Internet through a firewall, it must be configured to process the extended HTTP commands used by WebDAV.
If your web server is configured to redirect URLs to a different server (for example, if you are using JkMount
in Apache to redirect requests for certain file extensions to Tomcat), be aware that WebDAV will not be available for those resources if the server you are redirecting to does not support WebDAV in that context.
If you'd like to find out more about WebDAV, see the following Web sites:
http://www.webdav.org
http://httpd.apache.org/docs-2.1/mod/mod_dav.html
A WebDAV connection in JDeveloper makes it possible to view files and folders as part of a JDeveloper project. Use the procedure to create a WebDAV connection in JDeveloper.
WebDAV connections created in JDeveloper allow you to view files and folders as part of a JDeveloper project.
Note:
The same URL cannot be used for more than one WebDAV connection on the same JDeveloper client.
To create a WebDAV connection in JDeveloper:
Configure JDeveloper before accessing WebDAV-enabled servers on the internet if a proxy server is used to access the internet. Use the procedure to access a WebDAV-enabled server by means of a proxy server.
If you access the internet via a proxy server you need to configure JDeveloper before accessing WebDAV-enabled servers on the internet.
To access a WebDAV-enabled server via a proxy server:
WebDAV connections that are shown in the Application Resources section of the Applications window can be modified. Use the procedure to modify a WebDAV connection.
WebDAV connections are shown in the Application Resources section of the Applications window, listed under the Connections node.
Existing WebDAV connections can be modified.
To modify a WebDAV connection:
WebDAV connections that are shown in the Application Resources section of the Applications window can be refreshed to reflect the current contents of the WebDAV server. Use the procedure to refresh the contents of a WebDAV connection.
WebDAV connections are shown in the Application Resources section of the Applications window, listed under the Connections node.
To ensure that the folders and files accurately reflect the current contents of the WebDAV server, you can manually refresh the display of a WebDAV connection.
Note:
All folders and files listed for the WebDAV connection are refreshed. The properties of the folders and files, and their contents, are refreshed.
To refresh the entire contents of a WebDAV connection:
Delete a WebDAV connection from JDeveloper without the deletion affecting any file or folder on the WebDAV server. Use the procedure to delete a WebDAV connection.
WebDAV connections are shown in the Application Resources section of the Applications window, listed under the Connections node.
Deleting a WebDAV connection from JDeveloper does not affect any of the files or folders on the WebDAV server itself.
To delete a WebDAV connection:
You can subsequently recreate the connection, in which case the files and folders that were part of it will be shown beneath it again.
The workflow in a version control system involves checking files out, modifying them, and checking them in. Files are locked to prevent file conflicts.
As a general rule, your workflow in the version control system your team uses will follow this basic format:
Check out files from the repository
Make changes
Check in (or commit) files back to the repository
In some circumstances, you may find that other team members have been editing the same files that you are committing. This requires resolving file conflicts.
In addition, many version control systems allow you to lock a file so that other users cannot check it out. This prevents you from having file conflicts which need to be resolved.
A file needs to be check out from the repository before it is changed. A check out normally locks the file and prevents file conflicts.
Commonly, your version control system requires you to check out a file from the repository before you begin making changes to it. This logs your access to the file and, in many instances, locks the file you have checked out to prevent other team members from accessing it while you are editing it. This can help prevent problems where multiple team members make conflicting edits to the same file.
Subversion files that are checked out from the repository are copied on the local computer constituting the Subversion working copy. Use the procedure to check out modules from the Subversion repository.
To begin making edits and revisions to files in your project, you check out the files you will be working with. It is recommended that you check out the entire application from the Subversion repository, so that you will have access to all files in that application in your local work area. Subversion uses the term modules to refer to the application it is recommended you check out.
Note:
With Subversion, there is no "check in" procedure, so you do not check in files that you have updated and check them out again when you next want to work on them. Instead, when you have finished working on your local copies of files, you commit them to the Subversion repository to bring the files up to date.
When you check out Subversion files, they are copied from the Subversion repository to a new location (specified by you) on your local machine. This location and the files within it constitute the Subversion "working copy."
To check out modules from the Subversion repository:
Check out a specific version of a file from the Git repository to modify it. Use the procedure to check out a file.
Checking out a file from your Git repository makes that file available for changes and edits. You can also specify the revision you wish to check out.
To check out a file:
Git checks out the files you have selected. They are now available for editing.
After importing a JDeveloper project into the CVS repository, you can check out modules from the CVS repository. Use the procedure to check out modules from the CVS repository.
This is a configuration task you perform when you first start to use JDeveloper with files and folders that are under CVS source control. You perform this task once, after (if necessary) importing your JDeveloper project into the CVS repository.
To check out modules from the CVS repository:
Use the Open for Edit option available in Perforce for the Team menu to place a file on a changelist thereby locking the file for editing.
Unlike some version control systems, Perforce does not require you to explicitly check out a file. To begin editing a file in Perforce, select Team > Perforce > Open for Edit. This opens the Open Files for Edit dialog, which gives you the option of placing the file on a changelist, locking the file so that other team members cannot edit it simultaneously, and more. topicid:f1_pfcopenfilesforedit_html
You can start editing a file under Perforce control just by opening it from the Applications window. While the Perforce server is being contacted, you may experience a delay before you can type into the opened file. If you would prefer files to remain closed until you manually open them for editing, set the Automatically Open Files for Edit preference to off.
Updating files at the beginning of every work session is good practice to ensure that files have all the changes that were made and were checked in by team members.
Updating files at the beginning of every work session helps ensure that you have all the changes made and checked in by your team members. This reduces the amount of time you might have to spend reconciling changes later, because it helps ensure that you have the latest version of your files when you begin editing them.
Update local copies of files with files from the repository using the Update Working Copy option so that all the files in a checked-out working copy are updated. Use the procedure to update a working copy.
Once your Subversion repository is set up, you typically update your local working copy with files from the repository. This ensures that the files you work on contain all committed changes that others on your team may have made to the same files.
It is recommended that you perform the update operation on a working copy.
When you use Update Working Copy, all the files in your checked-out working copy will be updated, regardless of which node you have active in your application in the JDeveloper Applications window. The alternative is to select Update. This will only update the folder or file (and any child folders and files) that you have selected in the Applications window.
To update a working copy (recommended):
Update individual files, although not all files that have been modified by team members may get updated. Use the procedure to update individual files.
You can also update individual files. However, this runs the risk of not updating all files that may have been modified by your team members since the last time you checked them out.
To update individual files:
Use the JDeveloper Delete feature to remove a file from Subversion control. Use the procedure to remove a file from Subversion control.
If you wish to remove a file from Subversion control, use the JDeveloper Delete feature. This performs a “safe delete," which searches for usages of the file you are deleting and provides you with a dialog with options for proceeding.
To remove a file from Subversion control:
Working with files in CVS involves checking out the latest version of a file, editing it, and checking the file in with changes. In CVS you can refresh the display of CS objects, add and remove files, compare files, or lock and unlock files.
As a general rule, working with files in CVS means checking out the latest version of a file, making your edits, and checking the file in with your changes. Occasionally, if you and a colleague have made edits to the same file, you may need to merge your changes to make sure your work is not lost. Other functions of CVS are also available, such as adding a new file or removing unused/obsolete files from the repository, but your general workflow will follow the checkout-edit-checkin pattern.
The file operations in CVS include refreshing the display of CS objects, adding and removing files, using templates, comparing files, replacing a file in CVS, viewing the history and status of a file, locking and unlocking files, and working with revisions and tags.
The Applications window displays source control status of objects by means of icons.
The source control status of an object is indicated in the Applications window by an icon overlay, as listed in Table 6-1.
Table 6-1 CVS Object Status
Icon | Description |
---|---|
|
The object has been copied from the CVS repository and added to your working files directory. |
|
The object is not under CVS source control, but may be added to the CVS repository. |
|
There were conflicts when the object (a file) was updated from the CVS repository. In this case, you have to manually edit the file to resolve all the points of conflict. |
|
The object has been scheduled for removal from the CVS repository with the next commit action. |
|
The object is out of sync with the CVS repository due to local or remote changes. |
|
The object is unmodified since it was last copied from the CVS repository. |
|
The object is unmodified since it was last copied from the CVS repository but is read-only. |
|
The package or node is a CVS sandbox folder. |
|
The apparent object may comprise several underlying objects, the statuses of which may not all be identical. |
A manual refresh of an object ensures that the status indicated in the Applications window matches the true status of the object in the source control system. Use the step to refresh the status of objects in JDeveloper.
If the status of an object is changed outside JDeveloper, for example by checking in an object using external source control software, the new status might not immediately be shown in JDeveloper. To ensure that the status indicated in the Applications window matches the true status of the object in the source control system, you can perform a manual refresh.
To refresh the status of objects in JDeveloper:
In the Applications window or CVS Navigator, click Refresh.
A file that is part of a project that is under CVS version control can be added to CVS. Use the procedures to add a file to CVS through the Applications window, to add files shown in the Pending Changes window, and to remove a file from CVS.
You can add a file to CVS only if it is part of a project that is already under CVS version control.
When you create a new file, for example a new class, it has to be added to source control before you can use the other CVS operations on it. The file is added to source control locally, and the CVS repository is not updated. The file is identified in the Applications window by the icon +.
After completing setup, your work will revolve around the following:
Updating your files from the repository
Checking out the files you need to work on
Editing them in JDeveloper
Committing the modified files back to the repository
You may also need to resolve conflicts between changes you made and those made by others in your team. Files may also be moved in and out of CVS control as the project changes. Finally, you might use special properties of the files associated with specific versions for tracking bugs, customer requests, and other characteristics.
To add a file to CVS through the Applications window:
Select the file in the Applications window and choose Team > Add (or, if the file is binary, Team > Add as Binary). JDeveloper usually recognizes binary files and adds (Binary) after the file name in the Applications window. The Add to CVS dialog (or Add to CVS as Binary dialog) is displayed, with the file listed.
Click OK.
The file will be added to the CVS repository when the next commit is performed.
To add files shown in the Pending Changes window:
With the Pending Changes window in Candidate Files mode, select the files that you want to add to source control.
To obtain more information about the Pending Changes window, press F1 or click Help.
Click the Add button.
To remove a file from CVS:
When you remove a file from CVS it is removed from your local disk.
The file or files will be removed from the CVS repository when the next commit is performed.
In the Git version control system, files are committed to import new files to a repository, and to check in changes after a file edit.
In the Git version control system, you commit files for two reasons: to make your initial import of new files to your repository, and to check in changes when you have made edits.
In Git, the basic file workflow is in three parts:
You initially create a local file system with the selected branch and content from your repository. You can do this using Team > Git > Clone.
You add new files to the repository: one at a time using Team > Git > Add, or multiple files with Team > Git > Add All.
As you edit files, you check them back into the Git repository one at a time with Team > Git > Commit, or multiple files with Team > Git > Commit All.
The following sections describe how to perform these operations.
The Git menu provides the Add option to add single files to the Git repository. Use the procedure to add a file.
To add a single file to your Git repository, use the Add command from the Git menu.
To add a file:
The file is added to your selected Git repository.
The Git menu provides the Add All option to add multiple files to a Git repository. Use the procedure to add multiple files.
To add multiple files to your Git repository, use the Add All command from the Git menu. This command adds all files in a directory.
To add multiple file:
All files in the selected directory are added to your Git repository.
Use Stashing to store modified tracked files and staged changes outside the working directory so that they can be reapplied later. Use the procedure to create a stash.
A file that has been changed has to be committed to the Git repository. Use the procedure to commit a change.
When you have made changes to a file, you can commit them to the Git repository.
To commit a change:
JDeveloper commits your changed file to the Git repository.
Changes to multiple files can be collectively committed to the Git repository. Use the procedure to commit multiple changed files.
When you have made changes to multiple files, you can commit them all to the Git repository in one operation.
To commit a number of changed files:
JDeveloper commits your changed files to the Git repository.
Apply stashes that have been created to the original files in the working directory. Use the procedure to apply a stash.
Perforce provides methods to determine changes between two revisions of a file, and to apply the changes to another file. Perforce also supports the export of details about repository connections and files in the repository.
Perforce provides features for creating and applying patches—methods for determining changes between two revisions of a file, and then applying those changes to a third file. In addition, Perforce contains features for exporting the details about repository connections, as well as files in the repository.
View the latest file statuses, and update files to synch with the repository version. Use the procedure to update files to match the controlled file versions.
Another person may edit a file through their Perforce client and submit their changes to the Perforce depot. This will cause your copy of the file to become out of date compared with the controlled version.
To test that your view is showing the latest file statuses:
Choose View > Refresh.
A file that is out of date with the controlled version is shown with an exclamation point icon.
To bring your files up to date compared with the controlled version:
Use Perforce Navigator to update a working directory with content from the depot. Use the procedure to synchronize files using the Perforce Navigator.
The Perforce Navigator lets you browse the Perforce depot and update your working directory from content at the depot. Using the Applications window, you can select folders or files to sync to your client workspace, downloading content from the Perforce Server to your computer. If new files are detected in the depot, you have several options for handling them.
If you open a connection node and no connection has been made, Perforce displays the connection dialog.
To synchronize your files using the Perforce Navigator:
To simplify working on several files, set filters in the Perforce client so that the filtered file view is displayed in JDeveloper. Use the step to filter files in JDeveloper.
If you have a very large number of files in your Perforce depot, it can be much easier to navigate to the files you're working on by filtering files in the Perforce workspace. You can do this by setting things up in the Perforce client, and then displaying the filtered view in JDeveloper.
Filtering files in Perforce (specifically, p4v) requires making sure that you are viewing the Depot Tree, then select the Filter icon > Tree Restricted to Workspace View.
To filter files in JDeveloper:
Version Navigator > Perforce > Connection name > Context menu - Filter by Client Workspace.
You will only see a difference in the JDeveloper Version Navigator if the Perforce client has a rule that restricts the Perforce workspace. (In p4v, the rules are shown and set in the View field of the Workspace dialog for the selected workspace.) You could restrict the workspace view in your p4v client with a rule like the following:
//depot/JDeveloper_1013/... //<client name>//JDeveloper_1013
In JDeveloper, if you select Filter by Client Workspace, the Applications window would be filtered so only //depot/JDeveloper
is shown.
Icons display the source control status of a file in the JDeveloper navigators. Use the step to refresh the status of files in JDeveloper.
The source control status of a file is indicated in the JDeveloper navigators by icon overlays, as listed in.
Table 6-2 Perforce Status Icons
Icon | Meaning |
---|---|
|
The file is in the Perforce client workspace but is not yet submitted to the Perforce depot. |
|
The file will be deleted when next submitted to the Perforce depot. |
|
The file is out of date compared with the Perforce depot. |
|
The file is up to date compared with the Perforce depot. |
|
The file is open for edit. |
|
The file is locked. |
If the status of a file is changed outside JDeveloper, for example by using a Perforce client application, the new status might not immediately be shown in JDeveloper. To ensure that the status indicated in the Applications window matches the true status of the file in the source control system, you can perform a manual refresh.
To refresh the status of files in JDeveloper:
Select View > Refresh.
Delete a file that it is under Perforce control by using the Perforce features within JDeveloper or the Perforce client application. Use the procedure to delete a file under Perforce control.
If you wish to delete a file that it is under Perforce control, you should do so using the Perforce facilities within JDeveloper or the Perforce client application.
If you need to retrieve a file that has been deleted, you will need to use the Perforce client. To do this, select Team > Perforce > Launch Perforce Client.
To delete a file under Perforce control:
In some version control systems, checking out a file automatically locks it, and checking it in unlocks it.
Not all version control systems explicitly require, or even have the facility for, locking files before editing. In some systems, checking out the file automatically locks it and prevents other team members from editing that file. In other systems, the files can be checked out by any team member, with the emphasis being on easily merging different changes to the resulting file.
The following sections explain how each version control system handles locking and unlocking a file.
A file that is locked in the CVS repository prevents other users from accessing it, and unlocking the file restores file access to other users. Use the procedures to lock files in CVS, and to unlock files in CVS.
Note:
The locking of files is not supported in newer releases of CVS client software and this facility may be removed in future releases of JDeveloper.
You can choose to prevent other users working on a file while you are working on it yourself. This is not normally considered necessary, because CVS can usually reconcile differing versions of files as they are being committed to the CVS repository. The JDeveloper compare and merge facilities will reconcile differing versions of files automatically, or present you with a tool for doing so manually if there are serious conflicts.
You may want to ensure that a file is worked on only by you, until you have finished working on it. This might be because a file is in binary format and therefore inherently difficult to merge. In this case, you can lock the file that you want to work on. The file is locked in the CVS repository, and other users are prevented from accessing it. When you want to let others work on the file, you unlock it.
To lock files in CVS:
With the file or files that you want to lock selected in the Applications window, choose Team > CVS> Administration > Lock.
Check that you want the operation to apply to all of the files highlighted in the file selection box.
Click OK.
To unlock files in CVS:
Open a file under Perforce control from the Applications window, or manually open files for editing by setting the Automatically Open Files for Edit preference to off. Use the procedure to edit a file under Perforce control.
By default, you can start editing a file under Perforce control just by opening it from the Applications window, without explicitly locking the file. While the Perforce server is being contacted, you may experience a delay before you can type into the opened file. If you would prefer files to remain closed until you manually open them for editing, set the Automatically Open Files for Edit preference to off. The following procedure works whichever way the preference is set.
To edit a file under Perforce control:
The changes that you made to the file are now saved in your Perforce client workspace. To add your changes to the controlled version of the file and make them available to other users, you must now submit them.
Files under Team System source control must be checked out so that you can work on them. Use the procedure to check out files.
Use to check out files so that you can work on them. The files must already by under Team System source control.
To check out files:
The status of a file that is under Team System source control can be checked. Use the procedure to view the status of a file.
You can check the status of a file that is under Team System source control. See also Refreshing the Status of Files in Team System.
To view the status of a file:
The status labels shown are those used by Team System to describe the source control status of the file.
The main statuses are:
Edited - In JDeveloper, the file is checked out and may have been modified.
Unchanged - In JDeveloper, the file is currently checked in.
Scheduled for addition - In JDeveloper, the file has been added (that is, brought under source control) but not yet checked in.
Icons display the source control status of a file in the JDeveloper navigators.
The source control status of a file is indicated in the JDeveloper navigators by icon overlays, as below.
Table 6-3 File status icons in Team System
Icon | Description |
---|---|
|
The object is checked in and must be checked out before it can be modified. |
|
The object is checked out and can be modified. |
|
The object is not under source control. |
|
The file has been brought under source control but has not yet been checked in to the Team System server. |
|
The object has been scheduled for removal from the Team System server the next time it is checked in. |
To refresh the status of files in JDeveloper:
Select View > Refresh.
When you check in a file, the local file version that has changed is uploaded to the central repository.
Checking in, sometimes called committing, is the process by which the changes you have made to your local file version are uploaded to the central repository. The following sections outline the procedures used by the various version control systems in use with JDeveloper.
Edited and revised working files must be committed as individual files or as change sets to update the Subversion repository with the latest version of the files. Use the procedures to commit a working copy from the Applications window or from the Pending Changes window.
Once you have made edits and revisions to your working files, you return them to the Subversion repository.
Use these procedures to bring the Subversion repository up to date with the latest version of the files you have been working on, at the same time adding any new files to or removing any unwanted files from the Subversion repository.
You can perform the commit operation on individual files, or in the context of a working copy.
If an individual object that you want to commit has uncommitted parent objects, you must first commit the parent objects. An alternative is to commit the working copy that the objects are part of, in which case all the uncommitted objects will be committed.
You can also use change sets to manage groups of files, which can help ensure that you commit all files pertaining to a particular sub-project or task within the overall application.
To commit individual files shown in the Applications window or the Pending Changes window:
Select the file(s) and choose Team > Commit.
The Commit Resources dialog is displayed with any files listed. Set the options on the Commit Resources dialog as required.
To obtain more information about the options, press F1 or click Help. To commit the listed file or files to the Subversion repository, click OK.
To commit a working copy from the Applications window:
Select a navigator node or file that is part of the working copy.
Select Team > Commit Working Copy.
To obtain more information about the options, press F1 or click Help. To update the Subversion repository with the content of the working copy, click OK.
When you use Commit Working Copy, all the files in your checked out working copy will be committed, regardless of which node you have active in your application in the JDeveloper Applications window. The alternative is to select Commit. This will only commit the folder or file (and any child folders and files) that you have selected in the Applications window.
Additionally, you can commit a working copy from the Pending Changes window.
To commit a working copy from the Pending Changes window:
Committing a file automatically saves a work item ID as a tag in the comment dialog.
If you are using Oracle Team Productivity Center, the work item ID will automatically be saved as a tag in the comment dialog when you commit.
You can either select an individual file to commit, or commit all files simultaneously. Use the procedures to commit an individual file, and to commit all files in a project.
There are two options for committing your changes to the Git repository: selecting an individual file to commit, or committing all files at once.
To commit an individual file:
Select the file you wish to commit.
Select Team > Git > Commit. This opens the Save Files dialog. Click OK to continue. This opens the Commit dialog.
If your team uses comment templates (for example, to make it simpler to track issues automatically in a bug-tracking system), select the template or add a comment. Otherwise, click OK to commit the file to the repository.
To commit all files in a project:
Update the CVS repository with the latest version of working files, and add, or remove files from the repository. Use the procedures to commit individual files or the contents of project folders shown in the Applications window, and to commit files shown in the Pending Changes window.
Use these procedures to update the CVS repository with the latest version of the files you have been working on, and to add any new files to or remove any unwanted files from the CVS repository.
You can perform this on a single file, or in the context of a project. When in the context of a project, JDeveloper determines which files have changed since they were last committed and displays them as a list.
If you select a project to be committed that includes files that are not yet part of CVS version control, the Add Files to CVS message dialog will open. To obtain information about using this dialog, press F1.
You can view the current contents of the CVS repository through the CVS Navigator. The nodes under CVS unfold to reveal the structure and file content of the CVS repository. You can open a read-only version of a CVS repository file by choosing Open from its context menu. This will let you see what changes have been made to the files in the CVS repository since you checked out or updated your local versions.
To commit individual files shown in the Applications window:
Select the file(s) in the Applications window, and then choose Team > Commit.
The Commit to CVS dialog is displayed with the file(s) listed.
Set the options on the Commit to CVS dialog as required.
To obtain more information about the options, press F1 or click Help.
To update the listed file(s) in the CVS repository, click OK.
To commit the contents of project folders shown in the Applications window:
Select the project folder(s) in the Applications window and, from the context menu, choose Versioning > Commit Project Folders.
If there are files in the project that are not under CVS control, you will be asked whether you want to add them.
The Commit to CVS dialog is displayed with the folder(s) listed.
Set the options on the Commit to CVS dialog as required.
To obtain more information about the options, press F1 or click Help.
To update the listed file(s) in the CVS repository, click OK.
To commit files shown in the Pending Changes window:
Changes made to a file are initially saved in the Perforce client workspace until they are submitted, and made available to other users. Use the procedure to submit changes to the Perforce depot.
Any changes that you make to a file are initially saved in your Perforce client workspace. To add these changes to the controlled version of the file and make them available to other users, you must submit them. In the following procedure, if the Submit menu option is unavailable, it is because there are unresolved conflicts between your copy of the file and the one in the Perforce depot. Before proceeding, you will have to resolve the conflicts or revert the file to a non-conflicting version.
To submit changes to the Perforce depot:
A file that is checked in to the Team System server can be seen and worked on by other users. Use the procedure to check in files.
Use to check in a file to the Team System server. A checked in version of a file can be seen and worked on by other users.
To check in files:
Version control systems such as Subversion and Perforce use change sets or changelists to group files, which form part of a single logical group, together.
Some version control systems (notably Subversion and Perforce) use the notion of change sets or changelists to group together files which form part of a single logical group. For example, you might be adding a new feature to an application which has a number of specific files: the HTML framework which calls a JavaScript function, the JavaScript file which contains the function itself, and a set of image files which represent the various states of the button before, when and after the user clicks on it in the final application. You might choose to group all these files in a single change set, as a way of tracking them and ensuring that you commit all of them to the repository (or that you refer to all of them in your team's tracking or build software).
The following sections describe how to use change sets or changelists in the version control systems that support them.
Adding files to change sets or change lists enables group operations on working copy files. Use the procedure to add a selected file to a new change set.
Change sets, or change lists, are essentially labels which can be applied to working copy files to enable group operation on each change list. The idea behind adding files to a change set is similar to sorting files into directories, but change lists can be created dynamically and the labels applied to each file, regardless of their level in the file system hierarchy. You can then address all the files in the change set as a single group. For example, if you make a single bug fix that requires editing three different files, you can add all three files to the change set and track them as a single logical unit in the JDeveloper Pending Changes window.
Subversion lets you associate files with a named change set, either manually or automatically. You make additions to the change set through the menu system; automatic additions are also possible through default association, when JDeveloper detects outgoing changes.
You can browse changes for a named change set in a view of the Pending Changes window. From there, you can manipulate the change sets, and commit associated changes to the repository.
To add a selected file to a new change set:
Select a file from the Pending Changes window, then select Team > Add To > New Change Set.
To add file to a change set:
For every installed version control system, JDeveloper creates a default, unnamed change set. You can edit, delete, or set a selected change set as the default.
JDeveloper creates a default, unnamed change set for each installed version control system, and uses this change set until you specify another change set as the default. You can make changes to the content and the status of individual change sets, including this default change set, by right-clicking any change set and selecting from the following:
Use the procedure to create a Perforce changelist. In Perforce, grouping files into changelists simplifies working on the files.
In Perforce, changelists let you group files together to simplify operations. Once files are grouped in a changelist, you can check them out and submit them all in a single operation.
In Perforce, changes are submitted to a Perforce repository using a changelist. This lets you group changes to several files into a logical unit, and then submit this unit to the Perforce repository in one operation.
You can have more than one changelist. You may find it useful to create changelists for specific projects, for related groups of files, or for any other grouping of files that you find create a logical unit, based on the way you and your team work. You can also move files from one changelist to another.
In general, you use changelists by following this workflow: create a changelist, add files to your changelist, edit your files and submit your changelist with the edited files.
You can also browse existing changelists through the Changelist Browser. The Changelist Browser also lets you create, submit, and move files between changelists. If the submit operation fails on any file in the changelist, then the whole changelist fails. This means the Perforce repository is left in a consistent state.
A Perforce changelist lets you manipulate a number of changed files and folders in a single operation, simplifying the process when you have several files that you have been working on.
To create a Perforce changelist:
Annotations to a Perforce revision or changelist are saved as comments with links to every file in the revision making it possible to see changes as annotations to files. Use the procedure to add annotations to a changelist.
Annotating a Perforce revision or changelist lets you store the Perforce revision or changelist as a comment linked to every file in the revision. When you modify these files later in Perforce, you can view the sequence of revisions or changelists to these files, as annotations to the files.
To add annotations to a changelist:
Any previous annotations will be visible in the Comments field of the changelist.
A Perforce changelist makes it possible to manage several changed files and folders through single operations. Use the procedure to add files to a changelist.
A Perforce changelist lets you manipulate a number of changed files and folders in a single operation, simplifying the process when you have several files that you have been working on. When you add files to Perforce, you can select the changelist to which these files will be added at the same time, through the Open for Add menu.
To add files to a changelist:
If files have been added to a changelist, a series of edits to the files can be submitted in a single operation. Use the procedure to select and submit the files in a changelist.
Once you have made a series of edits to your files, you are ready to submit them in Perforce. If you have created a changelist, you can submit all the files on that changelist in a single operation, or select just the ones you have edited and submit them.
To select and submit the files in a changelist:
The Changelist Browser displays the name, description, and contents of every pending changelist, and allows you to browse the files that are associated with a changelist. Use the procedures to create a changelist with the Changelist Browser, submit it, and to move files between changelists.
The Changelist Browser lets you see, at a glance, the state of all the pending changelists in your Perforce repository. Each pending changelist is shown with its name, description, and contents. The default changelist is always shown at the top of the browser. Under each changelist, you can browse the files that are associated with that changelist. Additionally, the Perforce connection and client are displayed at the top of the browser.
From the Pending Changelist browser, you can create and submit changelists, move files between changelists, and refresh the browser.
To create a changelist with the Changelist Browser:
From the Versioning menu, select Perforce > Create Changelist.
From the Connection drop-down list, select the preferred Perforce connection (if you have more than one) for this changelist.
Select the files to be added to the changelist, or click Select All to add all displayed files to this changelist.
Add comments to this changelist, if desired. You can choose a previous comment (with the option of editing it if necessary), or you can select your comment template.
When you have set up the changelist as desired, click OK.
To submit a changelist:
From the Versioning menu, select Perforce > Submit Changelist.
Enter a description of the changes you have made in the Description field.
Check the files you wish to submit. Use the Select All and Deselect All buttons if required.
To move files between changelists:
You can also refresh the changelist browser by pressing F1.
Configure the comment templates in Subversion, CVS, Git, and Perforce to check in or commit files. The comment text in comment templates can be structured in a way that can be read by a bug-tracking system to associate file checkins with the issues that are being tracked.
Subversion, CVS, Git, and Perforce all let you configure comment templates to be used when checking in or committing files. One popular use for a comment template is to structure the comment text in such a way that it can be read by a bug-tracking system to correlate file checkins with issues being tracked. For example, beginning a comment with the string bugtraq
and then following with the issue number would make it possible to analyze comments automatically and generate a report of files and the bugs they were filed against.
The four version control systems that use comment templates all allow you to are Subversion, CVS, Git, and Perforce. The following instructions are common to all these systems.
In JDeveloper, create and select templates from the Commit or Checkin menu that provides for file checkin comments, which can associate the edits with the issues being tracked. Use the procedure to create a new template.
Many team environments allow the developer to enter comments when a file is checked in. These comments might include bug report numbers, dependencies on other files, or some other explanatory information to be stored in connection with the file being committed to the repository.
In particular, some teams wish to correlate checked-in files with the bugs that the files address. One way to do this is to set up a standard template for issue tracking, for example, bugtraq
<bug number>
where you replace <bug number>
with the actual ID of the issue this file addresses, and use that as the comment to a file checkin. This way, file checkin comments can be used to correlate the edits with the issues being tracked.
JDeveloper lets you create and select templates for use with such comments. The templates are available from the Commit or Checkin menu, depending on how your version control system refers to the process of committing changes to the repository.
To create a new template:
The template you created will now be available to select when you commit or check in your files.
Import and export templates as text files, and share a set of templates within a team. Use the procedures to import or export a template.
JDeveloper lets you import and export templates as text files, allowing you to share a set of templates with your team. This simplifies using the exact format that any tracking system you use will expect to see in the commit comments, and also avoids errors in formatting the template.
To import a template:
From the Comment Templates page, click Import. This opens a file browser.
Navigate to the directory containing the template file you wish to import and click on the file to select it.
Click Open.
The template file will be imported to JDeveloper.
You can also export your templates as a file to be imported later, either by you or (if you make the file available on a shared resource) by your team members.
To export a template:
my_bugtraq.xml
) and click Save.The template file is now available for import to JDeveloper.
Note that if your team uses more than one version control system, you can use Export and Import to share the same templates across systems.
Using the templates that are available from the Commit menu, enter comments when a file is checked in, and associate the edits that were made with the issues that are being tracked. Use the procedure to select a template.
Many team environments require the developer to enter comments when a file is checked in. These comments might include bug report numbers, dependencies on other files, or some other explanatory information to be stored in connection with the file being committed to the repository.
JDeveloper lets you create and select templates for use with such comments. The templates are available from the Commit menu.
To select a template:
Your file will be committed with the template you selected, plus any edits you made.
Shelving saves file changes in the Team System server without file check-ins thus allowing you to work on the changed files, to remove them from view, and revert to unchanged versions. Use the procedures to shelve and unshelve a set of file changes, and to delete a shelveset.
Shelving lets you save file changes in the Team System server without having to check the files in. As part of the shelving process, you can choose either to continue to work on the changed files or to remove them from view and revert to unchanged versions.
When you later want to make use of the file changes that were shelved, you can unshelve them.
If you decide you no longer want to keep changes that were shelved, you can delete the shelveset that you put them in.
To shelve a set of file changes that have not been checked in:
To shelve a set of file changes that have not been checked in:
In the Applications window, select the versioned project containing the files.
Select Team > Shelve.
The Shelve dialog opens.
Complete the dialog.
For information while completing the dialog, click F1.
The file changes will be shelved when you click OK.
The file icons in the Applications window will change to reflect the new file statuses, if any.
To unshelve a set of file changes:
In the Applications window, select the versioned project into which you want to unshelve the file changes.
Select Team > Unshelve.
The Unshelve dialog opens.
Select the shelveset name for the shelveset containing the file changes.
The file changes will be unshelved when you click OK.
Files deleted since the shelveset was created will be reinstated and the file icons in the Applications window will change to reflect the new file statuses.
To delete a shelveset:
The shelveset will be deleted when you click OK.
When working on multiple releases, use branches in Subversion, Git, and CVS to track, modify, and update each project for team work. Tags track file collections to capture the state of development at a specific point.
Many version control systems used with JDeveloper (notably, Subversion, Git, and CVS) use branches to keep track of development projects or streams. Branches are a useful way to separate out development when (as is often the case) your team is working on multiple releases -- for example, a patch release, a major update, and a new project -- at the same time. Tracking each of these projects as a separate branch in your version control system makes it easy to track, modify, and update each project with the correct feature set, bug fixes, and other changes, and to ensure that all members of the team are tracking the same issues on the same branch.
Tags, on the other hand, are a way of tracking collections of files that capture the state of development at a particular point. Where a branch represents a stream of development moving towards a particular release, product or version, tags are useful for tracking elements within a branch -- such as a specific bug fix that might affect multiple files in a given release.
In a version control system, a trunk represents the main line of development from which branches are created so that developers can work on files independent of the trunk.
To work on files independently of the main line of development (the "trunk") you can create a branch. Using the same feature, you can also create a tag, a collection of files that captures the state of development at a particular point. Creating branches varies slightly from system to system.
In Subversion, merge a branch with the trunk, compare the differences between two revisions, and apply the differences to the current working copy. Use the procedures to create a branch or tag, to use the merge facility, and to switch the working copy to another location in the repository.
When you wish to put the work you have being doing on a branch back into the main line of development, you can start the process by using the merge revision facility. This will compare the content of two revisions and apply the differences to the current working copy. You can also use this facility whenever you wish to copy changes made in one revision to another revision.
You may want to change your working copy so that it is based on a different branch. You can do this using the switch feature, either as part of branch creation or independently.
To create a branch or tag:
Ensure that you have committed your files to Subversion before continuing.
In the Applications window, select a project or file that is in the line of development that you wish to branch or tag.
Select Team >Branch/Tag.
Complete the Branch/Tag dialog.
For help when completing the dialog, press F1 or click Help.
To use the merge facility (that is, to compare two revisions and apply the results to the working copy):
In the Applications window, select a project or file that is in the start revision (that is, the resource that is to be compared against).
Select Team > Merge.
Complete the Merge dialog.
For help when completing the dialog, press F1 or click Help.
To switch the working copy to be based on another location in the repository:
Create a named branch of the Git repository, and apply a tag to the branch. Use the procedure to create a new branch in Git.
You can create a new, named branch of your Git repository, and optionally apply a tag when you create it, from the Create Branch dialog.This creates the named branch for use with Git, and associates the selected tag with it if you choose.
To create a new branch in Git:
Create a new branch to start work on a project based on an earlier code version, or create a new branch from an existing branch of the code trunk. Use the procedures to create a new branch, and create a new branch from an existing branch.
You create a new branch when you are beginning a project based on an earlier version of your code repository, such as for fixing bugs after a major release, or working on specific features for a subset of your customers.
To create a new branch:
In the CVS repository, select the file or folder on which you wish to base your new branch, then click the right mouse button.
Choose Branch > Branch in CVS.
Type in the branch name. JDeveloper converts the branch name to the default tag for the branch, by appending _BASE to the branch name as you type it.
Choose whether the branch source is the trunk or the working copy. If you select the trunk, the HEAD revision of every file is branched.
Click Save.
The base tag is applied before the branch is created, allowing you to specify these versions as a merge point in future.
You can also specify that you wish to create your new branch from an existing branch, by choosing the branch to use as the base.
To create a new branch from an existing branch:
Manage and track projects under version control by creating branches in the repository. Check out branches at the beginning of a project, check out individual files for edits or reviews, delete branches, or merge branches.
Once you have created a branch, JDeveloper presents a number of methods of using it to manage and track the projects you have under version control. Typically, you check out branches at the beginning of a project involving that branch, then later you can check out the individual files that you are editing or reviewing. You may also occasionally need to delete a branch (when a project is archived, for example), and you may also need to merge a branch.
To access files on a branch of code in a repository, you must check out the branch. Use the procedure to check out a branch in Git.
Checking out a branch in Git gives you access to the files on that branch.
To check out a branch in Git:
JDeveloper displays the branch that you have checked out, with any projects and files associated with the selected branch. You can access these files from the Application window.
Changes on a branch must be committed after the changes from the branch have been merged with the Head.
Note that after merging your changes from the branch into HEAD, you must still commit those changes. The changes will be available in the main repository after they have been pushed to the main repository
The Tag, Branch and Merge menus provide access to the branches that have been created to work away from the main branch of a project. Switch between branches, merge a branch with the trunk, check out or check in files on a branch, and commit changes.
CVS lets you define branches, used when development needs to be carried out separately from the main (or trunk) branch of a project. JDeveloper gives you access to CVS branches in your repository through the Tag, Branch and Merge menu.
In CVS, you can create a separate branch when you want to carry out specific work (such as bug fixes or specialized feature development) without any impact to the main set of files, also called the trunk.
Once you have created a branch, you interact with it as normally with CVS -- check out files, commit changes, etc. You can switch back and forth between branches, and you can merge the changes you have made to your branch back into the trunk.
CVS also lets you apply tags to specific branches, or to specific files in a branch (as well as generating a new tag for the branch you create, when you create it).
Branch selection is integrated into a number of CVS functions. You can switch branches or versions for files you are editing or have checked out; you can choose tags, branches, or version dates while updating the contents of your work area, as well as while you are checking out a CVS module.
Switch the branch or version of a file in JDeveloper. Use the procedures to select a branch, version or date from the Versioning menu, and to select a branch, version or date from the context menu of the project.
You can switch the branch or version of a file you are editing, either from the JDeveloper Versioning menu or from the file or project's context menu.
To select a branch, version or date from the Versioning menu:
From the Versioning menu, choose Tag, Branch or Merge > Switch Branch or Version.
Click the chooser to display a list of branches or versions.
Select the branch or version you wish to use.
Optionally, click Add Date to specify a date to use.
Click OK.
To select a branch, version or date from the project's context menu:
When you update file content, you can also branch using the associated tag. Use the procedure to select a tag and branch while updating content.
When you are updating your content to capture the latest revisions to the repository, you have the option of branch (via its associated tag) at the same time.
To select a tag and branch while updating:
Use the procedure to select a branch while checking out a CVS module.
As with other CVS operations, tags and branches are integrated into the process of checking out a CVS module.
To choose a branch while checking out:
Tags identify logically grouped content such as a subset of files within a branch. Use tags to manage files in the version control system.
Tags give you another way of identifying content that is logically grouped in some way, typically as a subset of files within a branch (for example, a list of files associated with a particular feature set, or with a particular bug fix). Once you create tags, they can be used in a number of ways, in particular for checking out files from the version control system.
Either create a new tag when you check out a branch in Git, or create a tag using the Create Tag dialog. Use the procedure to create a tag in Git.
You have the option of creating a new tag when you check out a branch in Git. However, you can also create a tag at any time by using the Create Tag dialog.
To create a tag in Git:
Create and assign tags to content in CVS. Use the procedures to assign CVS tags, to view CVS tags, and to reset CVS tags.
CVS allows you to create and assign tags to content.
To assign CVS tags:
This procedure will assign symbolic tags to the local CVS revisions of selected files.
In the Applications window, select a single file, a project or a workspace. If you select a project or a workspace, all the files within the project or workspace will be selected for tagging.
Choose Team > Tag > Tag.
Check that you want the operation to apply to all of the files highlighted in the file selection box.
Enter a name for the tag in the Tag Name box.
Set the other options as required. To obtain descriptions of the options, press F1.
Click OK.
To view CVS tags:
This procedure will display a dialog containing information about any existing tags that have been applied to the file revision.
From the context menu of the file, choose Team > Properties.
Select the Versioning tab. The sticky tag, date and options (if any) are shown, as is a list of existing tags for the file revision.
To reset CVS tags:
This procedure will remove any sticky tags or dates that have been applied to the selected files and reset them to the HEAD revision.
Delete the tag from a file, or from all the files within a project or workspace. Use the procedure to delete CVS tags.
Deleting a tag does not delete the content associated with it, but if you are using tags to identify a specific project that has completed, you can delete the tag to simplify the display when you are choosing tagged content in future.
To delete CVS tags:
This procedure will delete symbolic tags from the local CVS revisions of selected files.
In Subversion, creating a tag is like creating a branch.
Use the Tag option from the Team menu to select a tag in Git, and apply it to a selected file.
You can select from an existing tag in Git and apply it to the file you have selected for the current transaction.
To select a tag in Git:
Select Team > Tag. Scroll through the list to find the tag you wish to apply to the selected file.
If there are more than one tags that apply to the file, hold down the Ctrl key, then select each tag that you wish to use.
In CVS, use tags as identifiers for branches, files, folders, or projects that are to be managed as logical groups. In addition to context menus, tags are available from the Tags option on the CVS menu in the Team category.
Tags in CVS are a way of identifying branches, branch-specific content, or other content that you wish to identify and manipulate as a single logical group. You can tag files, folders, or projects. You can then later use these tags to identify branches, update files from a branch with a specific tag, and other operations.
You can select and browse tags from context menus as well as the Team > CVS > Tags menu. The availability of tags differs depending on the context of the operations you are performing on your content.
A project that has a tag identifier can be accessed by selecting the tag from any CVS menu. Use the procedure to add a tag to a project.
You can identify a project by adding a tag to it. You can then operate on this project by selecting the tag from any of the CVS menus that contain the tag chooser.
To add a tag to a project:
In the Update from CVS dialog, you can select and apply a tag. Use the procedure to select an existing branch, version, or date from the Projects view.
You can choose and apply a tag while using the Update from CVS dialog.
To select an existing branch, version or date from the Projects view:
Deleting a tag removes it from the list of available tags, and from the resources to which it had been applied without removing the associated content. Use the procedure to delete a tag.
You can also delete a tag. Deleting a tag removes it from any resources to which you have applied it. Deleting the tag does not delete the content to which the tag was applied; it merely removes it from the list of available tags.
To delete a tag:
In this context, only existing tag versions (regular non-branch tags) can be selected.
With Subversion, you can define and add properties to files, folders, and other resources in the Applications window.
Subversion lets you define and add properties to various levels of the elements in the Applications window: files, folders, and other resources. You can define these properties and use them as a way of tracking files or folders that have something in common.
Associate a specific subversion property with a newly added feature to see all the files associated with the feature. Subversion allows you to specify the Resource file, Property name, Value string, Value file, and Set property recursively properties.
As an example of using subversion properties, you can associate a specific subversion property with a newly added feature. Viewing all files or folders with this subversion property lets you see all the files associated with this feature: an HTML file, a JavaScript file, a class definition file, or any other elements that are involved in adding this new feature to your application.
When you add or edit subversion properties, the dialog lets you select or specify the following elements:
The file (or folder or other resource) to which this property is to be applied. To change this value, select a different file or resource. Note that if you wish to add this property at the application or project folder level, edit the resource file entry so that it refers to the folder, not the file.
Select a property name from the available list, or enter a new name to create a new Subversion property. Preface the new property name with svn: to be tracked as a Subversion property.
Enter the string to be displayed with this Subversion property when you view properties. For example, you can associate a specific Subversion property with a particular bug identification number or a specific upcoming release.
Note that the Value String might differ depending on the property. For instance, consider a property named svn:externals
meant to record the connection between a local file and its external URL in the SVN repository. This property's value string would be a pair of text strings, respectively showing the local directory where the external file is to be checked out and the URL to the external file in the SVN repository
Assume for this example that the resource file is D:\temp
and the property name is svn:externals
. The value string (a value pair) might be:
external_libs https://ukp16449.uk.oracle.com/repos/trunk/FOD/StoreFront.jar
This indicates that the file StoreFront.jar
held in the Subversion repository at that URL is to be checked out to D:\temp\external_libs
. If the Value String entries were held in a specific file pointed to from this property, use the Value File entry.
Use View Subversion Properties to see a list of all elements that use a selected Subversion property, and to compare the Subversion properties between different versions. Use the procedures to view a list of Subversion properties, and to add a new Subversion property.
If your team has been using Subversion properties for some time, you can use the View Subversion Properties menu to see a list of all elements that use a selected Subversion property. You can also compare the Subversion properties between different versions.
To view a list of Subversion properties:
Select an element under Subversion control from the Applications window.
Select Team > Subversion > View Subversion Properties.
If your project needs a new property for tracking and managing a particular aspect (such as a new feature or a bug fix), you can also add new properties.
To add a new Subversion property
When you set an external property with a revision number, make sure you follow the correct format for the value string. You can use either of the following as the value string for a property of type svn:external to set the ExternalWebINF revision to 16, using the JDeveloper integrated Subversion:
ExternalWebINF -r 16 https://myserver.myteam.com/svn/repos/public-html/WEB-INFhttps://myserver.myteam.com/svn/repos/public-html/WEB-INF@16 ExternalWebInf
Check the content status and any associated property status of a file that is under Subversion source control, or refresh the status of a file. Use the procedure to view the status of a file.
Use this procedure to check the content status and any associated property status of a file that is under Subversion source control. You can also refresh the status of a file.
To view the status of a file:
The status labels shown are those used by Subversion to describe the source control status of content and any associated property.
The main statuses for content are:
added - The content has been added to source control but has not yet been committed to the Subversion repository.
modified - The property has been locally modified since it was copied from the repository.
unmodified (normal) - The property is unmodified since it was last updated from the Subversion repository.
conflicted - There were conflicts when the property was updated from the Subversion repository.
deleted - The file (content and any associated property) will be removed from the Subversion repository with the next commit action.
The main statuses for associated properties are:
modified - The property has been locally modified since it was copied from the repository.
unmodified (normal) - The property is unmodified since it was last updated from the Subversion repository.
conflicted - There were conflicts when the property was updated from the Subversion repository.
If there are versions of files or folders with conflicting properties, resolve them using the Resolve Conflicts option in the Subversion menu for Team. Use the procedure to resolve Subversion property conflicts.
Subversion allows you to create and save properties associated with folders or files. These properties have a name and a value string.
You can resolve any such conflicts using Subversion's Resolve Tree Conflicts feature.
To resolve Subversion property conflicts:
This displays the versions with the conflicting properties in two adjacent panes, as with the Version Compare.
To resolve the conflict, you can make changes in the Subversion Properties window.
Version control enables you to view file history, and compare the differences between file revisions.
One of the most useful parts of working with version control is the ability it gives you to look at the history of a file and compare changes made to different revisions. In debugging, you can look through the file history to find a version just prior to the introduction of a defect, which can help you identify where the problem occurred. If you and another team member make conflicting changes to a file or a set of files, you can go back to versions of the file from before the changes were made.
Subversion provides the History Viewer that displays the change history of a file in the repository during the life cycle of a project. Use the step to view the history of a file.
You can refer to the history of a file in your repository to review changes made to it over the life of the project.
To help you understand the sequence of changes made to a specific Subversion file, you can use the History Viewer and view the history of Subversion files.
To view the history of a file:
With the file selected in the Applications window, choose Team > Version History from the context menu.
For more information while using the History Viewer, press F1 or click Help.
Icons in the Applications window and the Teams window show the source control status of a file, and this status can be manually refreshed. Use the step to refresh the status of files in JDeveloper.
The source control status of a file is indicated in the JDeveloper navigators (Applications window and Teams window) by icon overlays, as below.
If the status of a file is changed outside JDeveloper, for example by using a Subversion client application, the new status might not immediately be shown in JDeveloper. To ensure that the status indicated in the Applications window matches the true status of the file in the source control system, you can perform a manual refresh.
To refresh the status of files in JDeveloper:
Select View > Refresh.
In Subversion, you can replace a file with its base revision. Use the procedure to replace a file with the Subversion base revision.
Use this procedure to replace a file with the base revision. The base revision is the revision from which the one you are currently working on originated.
To replace a file with the Subversion base revision:
Cancel changes that have not been checked in by undoing changes, or reverting to specific, previous versions of files.
Undo changes, revert to previous versions, selecting specific revisions: these are all commonly used phrases to describe the process of canceling changes you have decided not to check in to the repository.
The Revert command in Subversion undoes changes, changes file status, and halts file removals. Use the procedure to revert a file.
Use the Revert command to:
Undo changes that you have made locally to the contents of a file.
Change the status of a file that has been added, but not yet committed, back to unadded.
Stop a file that is scheduled for removal (in the Pending Changes window) from being removed from the Subversion repository.
To revert a file:
The changes that were made to a file that has been committed to a Git repository can be reverted. Use the procedure to revert changes.
You can revert changes made to a file that you have committed to a Git repository to return it to a previous state.
To revert changes:
In CVS, select a specific revision from the CVS repository to work on. Use the procedure to open a CVS file revision.
CVS lets you select specific revisions from the CVS repository, if you find it necessary to begin or resume working with a previous version of the file you are currently working on.
To open a CVS file revision:
This procedure will obtain a revision of a file from the CVS repository so that you can view it or save it locally.
Merge changes from different files to get a single version which contains edits from many members of the team.
Many version control systems offer ways to let you merge changes from different files, ending up with a single version which contains edits from multiple team members. To begin, you will need to compare different versions of the file, then follow the procedures for selecting and merging changes.
Files that are under Subversion control can be compared with other revisions of the same files, or with other files. Use the procedures to compare revisions of a file, to compare a file with another file, and to compare two files.
Use these procedures to compare files that are under Subversion control with other revisions of the same files, or with other files.
To compare revisions of a file:
From the context menu for the file, choose Compare With.
Select either Previous Revision, Latest Revision, or Other Revision.
If there are no differences, a message is displayed. Otherwise the revision or revisions are shown in the Compare panel of the History tool.
To compare a file with another file:
From the context menu for the file, choose Compare With > Other File.
The Select File to Compare With dialog is opened.
Select the file to be compared.
The files are shown in the Compare panel of the History tool.
To compare two files:
You can hide (and later expose) the Compare panel of the History tool to view other panels in JDeveloper.
In the event of a conflict between the working copy of a file and the one in the Subversion repository, resolve the conflict or revert to a non-conflicting version of the file. Use the procedure to resolve the conflicts using the merge tool.
If there is a conflict between your copy of the file and the one in the Subversion repository, the icon next to the affected file will include an exclamation point. You will not be able to submit such a file to the Subversion repository. To overcome this problem, you should do one of the following:
Revert to a non-conflicting version of the file.
Resolve the conflict using the JDeveloper merge tool.
Indicate to the Subversion control system that the conflict has been resolved (Team > Mark Resolved), even if no changes have been made (usually necessary only for binary files).
Another reason you might need to do this is if you have resolved the conflict yourself in the file, rather than using the merge tool. This might be the case if you have chosen to merge files at the server rather than the more usual solution of merging files locally.
To revert to a non-conflicting file version:
Select the file in the Applications window and choose Team > Revert.
To resolve the conflicts using the merge tool:
To indicate that the conflict has been resolved, even if no changes have been made:
Select the file (usually a file with binary content) in the Applications window and choose Team > Mark Resolved.
Two revisions of a file that contain conflicting content can be merged. Use the procedure to merge two revisions with conflicting content.
Use this procedure to merge two revisions of a file, where the revisions contain conflicting content. Conflicts are notified in the Pending Changes window: the outgoing status is "conflicts" or "conflicts on merge", and the Resolve Conflicts button is active.
To merge two revisions with conflicting content:
Merge tracking in Subversion records the merges that you completed. In the Merge Wizard, you can select specific revisions, branches, or change sets to merge.
The Merge Wizard is instrumental to the way that JDeveloper supports Subversion merge tracking. Merge tracking in Subversion means in essence that Subversion remembers your merges so you don't have to. The Merge Wizard provides you with an easy way of selecting which components you wish to merge, such as specific revisions, branches, or change sets.
The Merge Wizard gives you a number of options:
Select this when merging a range of revisions to another branch, for example, when you are back-porting a group of bug fixes to the release branch.
Normally used when merging the changes on a branch back to the trunk, for example, if you completed the work on a feature branch and want to reintegrate the changes back to trunk.
You can merge, compare, replace, and view different versions of files in the CVS repository.
CVS gives you techniques that allow you to merge, compare, replace, and view different versions of the files in your repository.
In CVS, two revisions of a file that contain conflicting content can be merged. Use the procedure to merge two revisions with conflicting content.
Use this procedure to merge two revisions of a file, where the revisions contain conflicting content. Conflicts are notified in the Pending Changes window: the outgoing status is "conflicts" or "conflicts on merge", and the Resolve Conflicts button is active.
To merge two revisions with conflicting content:
Revisions of files that are under CVS source control can be compared with the preceding revision of the file, or with earlier revisions. Use the procedure to compare a file shown in the Applications window.
Use these procedures to compare revisions of files that are under CVS source control. You can compare a file with its immediate predecessor, or you can compare with any of the file's previous revisions.
To compare a file shown in the Applications window:
To compare a file shown in the Pending Changes window:
You can compare a file in the Pending Changes window either with a previous revision or with the HEAD revision, depending on which mode the window is in. To obtain more information when using the Pending Changes window, press F1.
With the window in Outgoing Changes mode, select the file to be compared, then select the Compare with Previous Revision button.
With the window in Incoming Changes mode, select the file to be compared, then select the Compare with Head Revision button.
If there are no differences, a message is displayed. Otherwise the Compare tool is displayed.
In CVS, replace a file with the base or head revision, or with a file with a specific numbered or tagged revision. Use the procedure to replace a file with a CVS revision.
Use this procedure to replace a file with the base or head revision, or with a file with a specific revision number or tag. The head revision is the latest one. The base revision is the revision from which the one you are currently working on originated.
To replace a file with a CVS revision:
Knowing the history and status of a file helps a user modify or update the file. Use the procedure to view the status of a file, and use the step to view the history of a project or file.
The history and status of a file will tell you what has been done to it, and what has been done to it last. This can help you make the determination of what you need to do to bring the file up to date, or to begin making your own modifications.
Use this procedure to open the History Viewer and view the history of CVS files.
To view the history of a project or file:
With the project or file selected in the Applications window, choose Team > Version History from the context menu.
For more information while using the History Viewer, press F1.
Use this procedure to check the status of a file that is under CVS source control. You can also refresh the status of files under CVS control.
To view the status of a file:
Possible statuses are:
Changed locally - the file has been locally modified since it was copied from the repository.
Changed in repository - the file has been modified by another user since it was copied from the repository.
Locally removed - the file will be removed during the next commit.
Locally added - the file will be added during the next commit.
Up-to-date - the file is up-to-date with the latest CVS repository revision.
File has conflicts - these may have resulted from a file update or commit action. If necessary, consult your CVS administrator for assistance.
Needs merge or needs patch - the file has been updated externally, for example, by another user.
Modified - the file previously had merge conflicts, but the timestamp has changed since.
Use Perforce tools to resolve conflicts in file versions because conflicts prevent the submission of files. Use the procedure to revert to a non-conflicting file version.
Perforce provides tools for resolving conflicts in file versions.
If there is a conflict between your copy of the file and the one in the Perforce depot, the icon next to the affected file will include an exclamation point. You will not be able to submit such a file to the Perforce depot. To overcome this problem, you should either revert to a non-conflicting version of the file, or resolve the conflict.
To revert to a non-conflicting file version:
Select the file in the Applications window and choose Team > Revert.
To resolve conflicting file versions (assumes use of Perforce merge tool):
Use Team System tools to view, compare, and resolve conflicts in files in the repository.
Team System provides tools for working with file versions, including viewing, comparing, and resolving conflicts among different files in the repository.
If Team System displays a system message about file conflict, either resolve the conflict, or revert to a non-conflicting version of the file. Use the step to revert to a non-conflicting file version.
If there is a conflict between your copy of the file and the one in the Team System server when you attempt to check it in, you will see a message box saying that the operation cannot be completed. To overcome this problem, you must first cancel the check-in operation, then do one of the following:
Revert to a non-conflicting version of the file.
Resolve the conflict using the merge tool in the Team System client software.
To revert to a non-conflicting file version:
Select the file in the Applications window and choose Team > Undo.
Undo the changes made to a file using the Undo option in the Team menu.
Use to undo the most recent change to a file.
To undo changes:
In Team System, you can replace a file with the base version, the source of the working copy of the file. Use the procedure to replace a file with the Team System base revision.
Use this procedure to replace a file with the base version. The base version is the version from which the one you are currently working on originated.
To replace a file with the Team System base revision:
History Viewer displays the history of files under Team System control. Use the step to view the history of a file.
Use this procedure to open the History Viewer and view the history of files held under Team System control.
To view the history of a file:
With the file selected in the Applications window, choose Team > Version History from the context menu.
For more information while using the History Viewer, press F1.
In Team System, compare files with other versions of the file or with other files. Use the procedures to compare versions of a file, to compare a file with another file, and to compare two files.
Use these procedures to compare files that are under Team System control with other versions of the same files, or with other files.
To compare versions of a file:
From the context menu for the file, choose Compare With.
Select either Previous Version, Latest Version or Other Version.
If there are no differences, a message is displayed. Otherwise the version or versions are shown in the History tool.
To compare a file with another file:
From the context menu for the file, choose Compare With > Other File.
The Select File to Compare With dialog is opened.
Select the file to be compared.
The files are shown in the Compare tool.
To compare two files:
The files are shown in the Compare tool.
JDeveloper supports External Tools to integrate external compare viewers. Use the procedure to integrate CVS DIFF.
JDeveloper has an integrated compare viewer that works well for most circumstances. However, you may prefer to use another compare tool or the simple output from CVS DIFF. JDeveloper lets you integrate third party tools and applications. This procedure describes how to use the External Tools support in JDeveloper to integrate external compare viewers.
To integrate CVS DIFF:
Use utilities such as Araxis Merge to view the differences between two revisions of a file in the history tool. Use the procedure to integrate a third party diff
utility.
You can use external tools macros to view differences between two revisions in the history tool using a third party utility such as Araxis Merge. The following steps will install a menu item to invoke Araxis Merge. For other utilities, consult the documentation of the utility to determine which command line arguments need to be passed in.
To integrate a third party diff utility:
In JDeveloper, select Tools > External Tools.
Click Add. This opens the Create External Tool wizard.
On the External Program Options page, enter the following information:
c:\araxismerge\compare.exe
)/wait /title1:"${file.name} revision ${cvs.revision}" /title2:"${file.name} revision ${cvs.second.revision}" /2 ${cvs.revision.file} ${cvs.second.revision.file}
On the Display page, enter a caption for the third party tool (for example Araxis Diff) in the Caption for Menu Items box.
Complete the remainder of the wizard as required. For help when using the wizard, press F1 or click Help.
Click Finish.
Other CVS commands can be integrated into JDeveloper using external tool macros. Use the procedure to integrate other commands.
You can take advantage of the supplied external tool macros to easily integrate other CVS commands into JDeveloper. An example is the CVS annotate command (sometimes referred to as “blame"), which shows a summary of who changed each line of code and when the change was made. To integrate a tool for CVS annotate, set the following options in a new tool.
To integrate other commands
Create and apply patches in JDeveloper using version control systems. Use the procedures to create and apply a patch.
Many of the version control systems available in JDeveloper provide features for creating and applying patches—methods for determining changes between two revisions of a file, and then applying those changes to a third file. In addition, Subversion contains features for exporting the details about repository connections, as well as files in the repository.
Subversion (included in JDeveloper) uses the following procedures for creating and applying patches. In addition, the version control extensions for Concurrent Version System (CVS), Perforce and Team System all use the same steps for creating and applying patches.
To create a patch:
This generates a patch comprising the differences between a controlled revision of a file and a revision of the file held locally.
In JDeveloper, open the file for which you want to create a patch.
Click the History tab.
The History view lists all the revisions of the file. In the lower portion of the History view, the left pane shows the contents of a local revision, and the right pane shows the contents of the controlled revision.
Select the revision combination for which you want to create a patch.
From the context menu, choose Generate Patch.
The Select Patch Context dialog may open. For help while using this dialog, press F1 or click Help.
The Generate Patch dialog opens. Complete the dialog as required. For help while using the dialog, press F1 or click Help.
To apply a patch:
Create and apply patches in JDeveloper using version control systems. Patches can be saved as separate files, or copied-and-pasted as sections into target files.
JDeveloper provides features for creating and applying patches—methods for determining changes between two revisions of a file, and then applying those changes to a third file. You can typically save these patches either as a separate file, or as a section of text to be copy-and-pasted into the target file.
Use a patch to record the changes between two revisions of a file, and to apply the differences to a third file. Use the procedure to create a patch.
You may wish to record the changes between two revisions of a file, then apply those changes to a third file. You do this by creating a patch and then applying it.
To create a patch:
This generates a patch comprising the differences between a controlled revision of a file and a revision of the file held locally.