The plugin allows for associating an IntelliJ IDEA Community Edition IDE project with a Perforce repository through IDEA's built-in VCS support.
Currently Supported IDEA versions: 13.5 through 15 which includes Android Studio 1.0
- Install the plugin by one of these methods:
- From within IDEA
- Open the IDE settings dialog ( File -> Settings... ).
- Navigate to the Plugins panel.
- Click the Browse repositories... button.
- Select the Perforce IDEA Community Integration plugin.
- Download and install from disk:
- Download from the Jetbrains plugin center or from the Github releases
- In IDEA, open the IDE settings dialog ( File -> Settings... ).
- Navigate to the Plugins panel.
- Click the Install plugin from disk... button.
- Select the downloaded zip file.
- Build it yourself:
- You'll need Ant 1.8 or better, a JDK 1.6, and the source code from GitHub on your local computer. You'll need a copy of p4d (or p4s for Windows) to run the tests. The code comes with copies of the correct dependent libraries. Note: the GitHub sources use a remote repository to host the large IntelliJ dependent Jar files.
- Copy the
local.properties.template
tolocal.properties
in the source root directory, and edit the values to match your configuration. - Run
ant
from the root source directory. - In IDEA, open the IDE settings dialog ( File -> Settings... ).
- Navigate to the Plugins panel.
- Click the Install plugin from disk... button.
- Select
p4ic4idea.zip
from the source root directory.
- From within IDEA
- In IDEA, select the VCS root directory managed by Perforce.
- Open the IDE settings dialog ( File -> Settings... ).
- Select the Version Control panel.
- Select the root directory from the list (or add a new one), and choose "Perforce" from the drop-down selection.
- Choose the Perforce connection method.
- From either the Version Control panel (select the pencil icon with the Perforce root selected), or the Perforce panel under the Version Control.
- Select the connection type and the parameters, and click OK.
In the Perforce configuration panel, you must choose the way in which the plugin connects to the Perforce server. There are several methods available.
For any of these methods, the Perforce server may request a password from you. If you choose the Save passwords option, the password will be stored application-wide, associated with that server and user name.
There are two methods available that allow you to directly declare the connection parameters, Client Password and Authorization Ticket.
Both of these connection types require you to enter the server connection string ("Perforce port") and the username. If a password is required, you will be prompted for it.
The "Perforce port" is usually just in the form "hostname:port number". SSL connections will need to use "ssl://hostname:port number".
Alternatively, you can use connection methods that simulate how the Perforce command-line clients connect to the server. All of these use the following standard keys:
P4PORT
: server connection string. SSL connections need to use the "ssl://hostname:port number" format.P4USER
: username used to connect to the server.P4PASSWD
: password used to connect to the server. If not provided, you may be required to enter it.P4TICKETS
: storage location for the Perforce ticket files. If present, the plugin assumes that the connection will perform a "p4 login" and store the associated ticket in that file.P4TRUST
: location of the trust ticket.P4SSLDIR
: directory containing the SSL connection information. Currently not supported.P4CONFIG
: these settings can be loaded from a configuration file. Note: P4CONFIG settings are only loaded from one file; you can't have config files referencing other config files.P4CLIENT
: Default client workspace name. You can override this in the UI.
This connection method uses the environment variables that launched the IDE as the connection properties. For Windows users, it also checks the registry entries for the corresponding values.
This currently doesn't support Mac OSX local settings.
Reads the connection settings from a single configuration file.
This is the only connection method that allows for multiple servers and clients to be referenced from a single project. This works by finding a P4CONFIG file (with the name given in the UI) which is in the current directory, or some parent directory, of each file being referenced. This replicates how the Perforce command-line tool searches for settings.
For example, with the file name set to .p4config
, you can put one
copy of this file into each module root directory. Then, each module will
have its files managed in their own client and server.
Some parts of the normal operation will act a bit differently. For instance, IDEA changelists can be associated with multiple Perforce changelists, if files from different clients are added to them. You can move files across servers, but these will be turned into simple add/delete operations. If you submit an IDEA changelist that is associated with multiple servers, then you will not be able to associate jobs with it.
With your working Perforce connections specified, you can use the IDE as usual. Editing files will check them out from the server. Moving or renaming files will trigger a P4 rename operation. Deleting files will delete them from the server. All edited files will show up in the IntelliJ change lists, and those will be associated with the corresponding Perforce change.
From the change lists, you can view a difference against the head revision. You can also view the file history, and compare different revisions against each other.
When submitting a changelist, you may associate Perforce jobs with the changelist, and set the job status. This association will only be used when the changelist is actually submitted.