[Getting Started]  [How To...]  [Browser Tips]  [Glossary]  [Road Map]  

Getting Started with Perforce and P4Web

This page is for users new to Perforce and P4Web. It describes how to use a P4Web Helper to do the common Perforce tasks: setting up a workspace, filling a workspace ("syncing"), working with files, and submitting files (in a "changelist"), and resolving files. Read this page first to get the most out of P4Web.

  1. Setting Up A Workspace

  2. Filling A Workspace with Files ("Syncing")

  3. Working on Files

  4. Submitting A Changelist

Setting Up A Workspace

The first thing you do when you use Perforce is to set up a personal client workspace on your local machine. You only have to do this once. You can't work with Perforce files until you've created a client workspace specification, or client spec.

In the P4Web control panel, select Go To->Edit Client Spec. Or click the "Edit Client Spec" shortcut button:

Edit Client Spec Shortcut to "Edit Client Spec"

This brings up the Edit Client Spec page, which contains a form. The important field to enter is the Root, which tell Perforce where on your local filesystem to put your workspace. For example, if you want your workspace to be located in the "c:\ws" path, enter "c:\ws" in the Root field.

After entering the workspace root, go to the bottom of the page and click Save. (There are other fields you can edit, but you can come back to them later when you have a better idea of how Perforce works.) You'll see the message "Client [name] saved." From this page, click the "Return to Browser" shortcut:

Return to Browser "Return to Browser" shortcut

If you ever need to change your client spec, just bring up this form again with Go To->Edit Client Spec.

Filling A Workspace ("Syncing")

Once you have set up your workspace you can fill it with files from the depot. In Perforce, this is called "synchronizing" your workspace, or "syncing" for short. Here's how you sync your workspace for the first time:

  1. Look in the upper left corner of the control panel and make sure you're in the Path Browser. If you're not, click Go To->Path Browser in the control panel.

  2. Beneath the Path Browser control panel you'll see the top level of the Perforce depot tree. Click on depot and path names to navigate down to the depot path you want to work on. Navigate down until the path shown is the one you want to sync. It will look something like this:

    Client view path:
    //depot/projects/gizmo/...
  3. Click the "Sync to Head Revisions" shortcut button.

    Sync to Head Revisions Shortcut to "Sync to Head Revisions"
  4. This puts you on a command result page that shows you which files are being copied from the depot onto your workspace. When the result page is completely loaded, your workspace is "in sync" with the depot. Return to the Path Browser where you'll see icons showing that your files are synced.

    Return to Browser "Return to Browser" shortcut
    Synced File "Synced File" icon

Note:

Updating ("Re-syncing") A Workspace

After you sync your workspace it can eventually get out of date because other people are submitting changes to depot files. You can re-sync your workspace to update it. Navigate to the path you want to update and click the "Sync" shortcut:

Sync Shortcut to "Sync Files"

When you sync, Perforce gets the files from the depot that are newer than the ones in your workspace. If you run sync more than once, nothing will happen the second time unless there are newer versions in the depot that are not yet in your workspace. Files that have already been copied to your workspace will not be copied a second time.

You should use sync regularly to update your workspace with the latest revisions of files. The files you are working on will be untouched when you sync. Read on to find out more about this.

Working on Files

Once you have synced your workspace you can work on files. You can edit files, add files, and delete files; these operations are called "opening" files. You can also revert opened files to their original state.

Note:

You can open an existing file from its File Browser page. Navigate to the directory that contains the file, then click on the file. This puts you in the File Browser, where you can run commands on a single file.

Editing files

To open a file for edit, navigate to its File Browser page and click the "Open for Edit" shortcut button. A page showing the result of the edit command will appear. Click the "Return to Browser" button to redisplay the File Browser page. You'll see a visual icon next to the file to remind you that you have it opened for edit.
Open for Edit Shortcut to "Open for Edit"
Return to Browser "Return to Browser" shortcut
Opened for Edit "Opened for Edit" icon

Once a file is opened for edit, it becomes writeable by you. Now you can use an editor or any other tool to modify the file.

Deleting files

If you want to delete a depot file, first you have to "open it for delete" in your workspace. To open a file for delete, navigate to its File Browser page and click the "Open for Delete" shortcut. A page showing the result of the delete command will appear. Click the "Return to Browser" shortcut to redisplay the File Browser page for the directory that contains this file. You'll see a visual icon next to the file to remind you that you have it opened for delete.
Open for Delete Shortcut to "Open for Delete"
Return to Browser "Return to Browser" shortcut
Opened for Delete "Opened for Delete" icon

When you open a file for delete, P4Web removes it from your workspace and lets the Perforce server know you are planning on removing it from the depot.

Adding new files

You must be in the Path Browser to open files for add. Navigate to the path in which you want the files to reside. Then select the Run->Add new files menu item. In the form that appears, list the files you want to add in the "Files" field, one file per line. Click the "Add New Files" button, then click the "Return to Browser" shortcut from the result page. The files you entered will be listed in the Path Browser with visual icons showing that they are opened for add.
Return to Browser "Return to Browser" shortcut
Opened for Add "Opened for Add" icon

Opening files for add tells Perforce you plan to add them to the depot. It doesn't create the files, however. You have to do that yourself, with an editor or any other tool.

Reverting files

Sometimes after opening files you realize you don't need to change them after all. In that case, you can use "Revert" to restore opened files to their original condition. You can use "Revert" either from the Path Browser or the File Browser. The former reverts all opened files in a particular path; the latter reverts a particular file.

The "Revert if Unchanged" shortcut can be used to automatically revert files you have opened for edit as long as you haven't changed them. Navigate to the path or file in question and click the "Revert if Unchanged" button. Then click "Return to Browser":

Opened for Edit "Opened for Edit" icon
Revert if Unchanged Shortcut to "Revert if Unchanged"
Return to Browser "Return to Browser" shortcut

Neither files that you have modified nor files opened for add or delete can be reverted using a shortcut. To revert those files, navigate to the path or file in question and select Run->Revert from the menu bar. Click Revert to run the command after you've selected your options. From the result page, click the "Return to Browser" button:

Return to Browser "Return to Browser" shortcut

Caution:

In the Revert options page, you must leave the "Restrict to unchanged files" checkbox blank if you want to revert files opened for add or delete. Files you have opened for add remain intact after they are reverted so you don't have to worry about losing them. However, P4Web overwrites files opened for edit when you run revert this way, discarding any workspace changes you have made to them. Use the "Selected Files" option in the form to de-select any files with changes you don't want discarded:

Restrict to unchanged files
Selected Files

Submitting A Changelist

As you open files you are building up a changelist. When you are satisfied with your changelist, you can submit it into the depot. "Submitting" copies opened files from your workspace to the depot -- until then, files in the depot are unaffected by your work. To submit your changelist, use the "Submit Default Changelist" shortcut button. It's visible on the Path Browser and File Browser pages.

Submit Default Changelist Shortcut to "Submit Default Changelist"

In the form that comes up, enter a description that explains why you are submitting these files. This description is stored permanently in Perforce and will be visible to anyone who looks at the history of any of the files in your changelist.

You don't have to fill in the Jobs field. It is used to associate jobs with changelists.

At the bottom of the form you'll see a checkbox list of all your opened files. If there are any you don't want to submit, uncheck them now. Then press the "Submit" button. A results page will show you whether or not your submit succeeded. After viewing the results, you can return to the Path or File Browser.

Return to Browser "Return to Browser" shortcut

Note: If any of the files you submit have been changed by someone else first, you'll get a submit error, as described below. This is perfectly normal. When it happens all you have to do is resolve your files and re-submit your changelist.

Submit errors

Sometimes when you've been working on files, other people will have submitted changes to the same files. If you haven't re-synced your workspace periodically and resolved files, you'll get a submit error when you try to submit your changelist.

Here's an example of what a submit error looks like:

	Submitting change 5047.
	//depot/dev/omni/svr/dynch.c - must resolve before submitting
	//socks-whitehouse/dev/omni/svr/dynch.c - must resolve //depot/dev/omni/svr/dynch.c#7 
	Out of date files must be resolve or reverted.
	Merges still pending -- use 'resolve' to merge files.
	Submit failed -- fix problems above them use 'submit -c 5047'
What this means is that your changelist has been assigned a number -- 5047, in this example -- but it has not been submitted. You'll have to resolve your files before you can re-submit your changelist.

Resolving Files

Resolving files is how you merge someone else's changes with your changes, when you've both been working on the same files.

For example, say you synced the file main.c to your workspace when it was at revision #6 in the depot. Then you opened it for edit. Then someone else submitted revision #7 into the depot. Resolving allows you to merge the changes from the depot's main.c#7 into the opened copy of main.c in your workspace.

Note that files in your workspace don't actually need resolving until you either re-sync your workspace, or get a submit error trying to submit files that have been changed in the depot by someone else. You can tell which of your files need to be resolved by looking for the "Needs Resolve" icon on files listed the Path Browser.

Needs Resolve "Needs Resolve" icon

In many cases you can resolve your files with the "Safe Automatic Resolve" shortcut. When you do this, P4Web compares your files and automatically handles the ones that can be resolved without perturbing changes you may have already made in your opened files. When you click the "Safe Automatic Resolve" shortcut, you'll get a result page showing which files were resolved this way. Click the "Path Browser" button to get a fresh Path Browser display.

Safe Automatic Resolve Shortcut to "Safe Automatic Resolve"

If there are "Needs Resolve" icons still showing in your Path Brower page, you'll have to use Run->Resolve... from the control panel. On the form that comes up, select "Resolve Interactively" and click the "Resolve" button. "Resolve Interactively" starts up a separate window running the Perforce interactive resolve program. It prompts you through your unresolved files and lets you choose what to do. For each file, you'll see information like:

	c:\ws\jam\main.c - merging //depot/proj/jam/main.c#7
	Diff chunks: 0 yours + 2 theirs + 0 both + 0 conflicting
...and a prompt like:
	Accept(a) Edit(e) Diff(d) Merge (m) Skip(s) Help(?) [at]:
Follow the prompt's advised action by hitting return. The prompt shows [in square brackets] which action it advises you to take. If there are no conflicting diffs, the merged result will be saved in your workspace file, and the resolve program will go on to the next file.

If there are conflicting diffs, you will be put into an editor to resolve the conflicts. The conflicts will be marked by lines beginning with >>>>, ====, or <<<<. For example:

     >>>> ORIGINAL
     i = i + j
     ==== THEIRS
     if ( i < n ) then i = i + j
     ==== YOURS
     if ( i <= n ) then i = i + j
     <<<< 
    
While in the editor, your job is to look for the conflicts, remove the conflict markers (shown here in red), and modify the remaining text in a way that makes sense. When you exit the editor, the prompt will advise you to accept the merged result.

You can choose to skip any file and resolve it later. Your workspace file will remain untouched if you choose to skip the file.

Re-submitting a changelist

A submit error will cause your changelist to be assigned a number. After you've resolved the files that caused the submit error, you can re-submit your numbered changelist using Go To->Pending Changelists in the control panel. Click on the changelist number you want to submit. Now you can submit your changelist following the instructions in submitting a changelist.


Copyright 2000 Perforce Software. All rights reserved.