Specify mappings
Remote specs consist of one or more mappings. Each mapping has two parts:
- The left-hand side specifies one or more files on the personal server.
- The right-hand side specifies one or more files on the shared server.
Although the two sides don’t have to name identical paths, they can.
Enclose paths with spaces in quotation marks.
Using wildcards in remote specs
To map groups of files in remote specs, you use Helix wildcards (*
, ...
).
Any wildcard used on the remote side of a mapping must be matched with an
identical wildcard in the mapping’s local side. You can use the following
wildcards to specify mappings in your remote spec:
Wildcard | Description |
---|---|
|
Matches anything except slashes. Matches only within a single directory. Case sensitivity depends on your platform. |
|
Matches anything including slashes. Matches recursively (everything in and below the specified directory). |
Now consider another remote spec’s simple depot path:
//stream/main/... //depot/main/...
All files in the shared server’s depot path are mapped to the corresponding
locations on the personal server. For example, the shared server file
//depot/main/widget-test/server.txt
is mapped to the personal server file
//stream/main/widget-test/servert.txt
.
Mapping part of the depot
If you are interested only in a subset of the depot files on the shared server, map only that portion. Reducing the scope of the personal server’s files also ensures that your commands do not inadvertently affect the entire depot. To restrict the personal server scope, map only part of the shared server depot to the personal server.
Example 1. Mapping part of the shared server depot to the personal server.
Remote Spec: //stream/main/... //depot/main/widget-doc/code/...
In this case, Helix will map only the shared server files under the code
subdirectory to the personal server’s //stream/main
directory.
Mapping files to different locations on the personal server
Remote specs can consist of multiple mappings; these map portions of the shared server file tree to different parts of the personal server. If there is a conflict in the mappings, later mappings have precedence over earlier ones.
Example 2. Multiple mappings in a single personal server
The following remote spec ensures that release notes in the remote p4-doc
folder reside in the personal server in a top-level folder called doc:
Remote Spec: //stream/main/src/... //depot/main/p4/... //stream/main/doc/... //depot/main/p4-doc/relnotes/...
Excluding files and directories
Exclusionary mappings enable you to exclude files and directories from being
mapped to a personal server. To exclude a file or directory, precede the mapping
with a minus sign (-
). Whitespace is not allowed between the minus sign and
the mapping.
Example 3. Using a remote spec to exclude files from a personal server.
Suppose you’re working on a game project and you don’t need the art files to be local:
Remote Spec: //stream/main/... //my_game/... -//stream/main/art/... //my_game/art/...