Skip to content

Latest commit

 

History

History
2319 lines (1811 loc) · 89.5 KB

RELEASE.md

File metadata and controls

2319 lines (1811 loc) · 89.5 KB
                        Release Notes for
                   P4Java, the Perforce Java API

                          Version 2024.2

Introduction

P4Java is a Java-native API for accessing Perforce SCM
services from within Java applications, servlets, plugins,
and other Java contexts.

Perforce numbers releases YYYY.R/CCCCC, for example, 2002.1/30547.
YYYY is the year; R is the release of that year; CCCCC is the
bug fix change level.  Each bug fix in these release notes is
marked by its change number.  Any build includes (1) all bug fixes
of all previous releases and (2) all bug fixes of the current
release up to the bug fix change level.

Please send all feedback to [email protected]

Requirements

* Perforce server at Release 2021.1 or higher.

* Java: full standard JDK 11 or later.  Implementation as
  discussed in "Known Limitations" below.

* SSL: unlimited strength JCE (Java Cryptography Extension) package for
  256-bit encryption level SSL connection to a secure Perforce server.

SSL and Trust

Perforce server 2021.1 or higher supports 256-bit SSL connections
and trust establishment via accepting the fingerprint of the SSL
certificate's public key. The standard JDK comes with 128-bit
encryption level ciphers. In order to use P4Java to connect to
a secure Perforce server, you must download and install the
unlimited strength JCE package for your JDK version.

To make a secure connection using P4Java, simply append 'ssl'
to the end of the P4Java protocol (i.e. 'p4javassl://perforce:1667').
For new a connection or a key change, you must also (re)establish
trust using the IOptionsServer's 'addTrust' method. See example
code snippet below:

// Create a P4Java SSL connection to a secure Perforce server
try {
    String serverUri = "p4javassl://perforce:1667";
    Properties props = null;
    IOptionsServer server = ServerFactory.getOptionsServer(serverUri, props);
    // assume a new first time connection
    // you should also handle a key change situation...
    server.addTrust(new TrustOptions().setAutoAccept(true));
    // if all goes well...
    IServerInfo serverInfo = server.getServerInfo();
} catch (P4JavaException e) {
    // process P4Java exception
} catch (Exception e) {
    // process other exception
}

P4Java 2020.1 has changed the default TLS support to TLSv1.2 for use 
with Perforce server 2019.1 or greater this can	be modified using the
JVM option:

    java -DsecureSocketEnabledProtocols=TLSv1.2 

Documentation

P4Java interfaces, classes, methods, etc., are documented in
the Javadoc tree included in the P4Java distribution and by
P4Java User Guide PDF also included in the distributed zip file.
Advanced usage issues, example patterns, etc., are documented
in the User Guide PDF.

Installation

After downloading the P4Java zip distribution file, unzip the
file's contents to a suitable directory. Copy or move the enclosed
P4Java p4java.jar JAR file to a suitable location for use by IDEs,
compilers, applications etc. Similarly copy or move the enclosed
Javadoc tree to a suitable place for browsing.

Known Limitations

* P4Java does not honor Unix / Linux umask settings on file
  creation and sync operations by default (this is a general Java
  JVM issue, not a P4Java issue). If this is an issue, you can supply
  a suitable
    'com.perforce.p4java.impl.generic.sys.ISystemFileCommandsHelper'
  interface as described  in the P4Java User Guide and associated
  Javadoc documents.

* P4Java is heavily reliant on the quality and performance of
  the underlying JVM's NIO implementation; if these are in any
  way limited or restricted on a target platform, performance
  and even correctness may suffer. P4Java is known to work
  correctly on the platforms listed above under "Requirements".

* P4Java can not reliably be used in Unicode contexts where files
  have been added to a Perforce server as "shiftjis" when they are
  in fact CP932 (or MS932) encoded, and vice-versa. The usual
  symptoms of this problem include being unable to sync or submit
  affected files, with an error message that includes the string
  "Translation of file content failed". This is a known problem due
  to the inability to define a robust round-trip encoding / decoding
  between these encodings and the inaccurate use of "shiftjis" to
  mean either true shift-jis or CP932 by the Perforce server and
  many Windows tools. There is currently no workaround known.

* The Perforce server (2021.1 or higher) only support 256-bit
  encryption.  Due to current US export control restrictions
  for some countries, the standard JDK package only comes with
  128-bit encryption level ciphers.  In order to use P4Java to
  connect to a secure Perforce server, those living in eligible
  countries may download the unlimited strength JCE (Java
  Cryptography Extension) version and replace the current
  default cryptography jar files with the unlimited strength
  files. These files are located at:

  <java-home>/lib/security/local_policy.jar
  <java-home>/lib/security/US_export_policy.jar
  
* P4Java would not support file operations on altsync enabled clients.

Updates in 2024.2 (2024.2/2695691) (2024/12/13)

#2693987 (Job #123372)
    Fixed a bug where localWhere should include path of the sparse stream instead 
    of the mainline from which the sparse stream is created

#2692452 (Job #123888)
    Added 'long' value support for 'TicketExpiration' field while login

#2693212, #2693848 (Job #123268)
    Added support of P4IGNORE from env variable working for absolute path
    Added support for all patterns in ignore file

#2687877, #2686707 (Job #122068)
    Added support of -m flag for "p4 protects" command

#2684594 (Job #123229)
    Added support for user case insensitive suboption for "p4 labels" command

#2684552 (Job #122974)
    Added support for user case insensitive suboption for "p4 clients" command

#2684551 (Job #122978)
    Added support for user case insensitive suboption for "p4 branches" command

#2684163, #2685729 (Job #123231)
    Added support for multiple client and user option with a generic case-insensitive
    sub option for "p4 changes" command

#2684163, #2681088 (Job #122972)
    Added support for client and user case insensitive option for 
    "p4 changes -c and -u"

#2684152, #2688244 (Job #121727)
    Added support for Sparse Streams

Updates in 2024.1 Patch 1 (2024.1/2674354) (2024/10/29)

#2672847 (Job #121791)
    Added support for "p4 attribute -I" and "p4 print -T" options.

#2672817 (Job #123136)
    Upgraded commons-io:commons-io to 2.17.0

#2669925 (Job #122392)
    Fixed an output bug with "Unable to determine client host name".

#2662969 (Job #122607)
    Added support to delete  client and all of its shelves via a single command.

Updates in 2024.1 (2024.1/2612262) (2024/06/12)

#2608430 (Job #120559)
    Added support for comments in the view mapping of Client, Branch, and Label Spec.

#2604468 (Job #120573)
    Upgraded P4Java to use Java 11.

#2597460 (Job #119320)
    Fixed a bug where the "Server.getExtendedFile(..)" throws NumberFormatException
    when headRev is #none

#2597531 (Job #112324)
    Fixed inconsistent handling of quotes in ViewMap for Label.

Updates in 2023.2 Patch 1 (2023.2/2581742) (2024/04/05)

#2578705 (Job #113772)
    Added support for "p4 renameclient" command.

#2578400 (Job #113890)
    Added support for "p4 opened -x" and "p4 opened -g" options.

#2551449, #2549979 (Job #118024)
    Added support for "p4 license -L" option.

#2577562 (Job #115953)
    Added support for "p4 sizes -c" option.

#2576245 (Job #115954)
    Added support for "p4 integrated -m" option.

#2558625 (Job #117352)
    Enhanced p4 print to return data in a byte buffer instead of creating a temp file.

Updates in 2023.2 (2023.2/2542382) (2024/01/16)

#2529385, #2525471 (Job #117013)
    Added support for 'Support Traits Depot' feature for attribute command

#2529385, #2525471 (Job #117014)
    Added support for 'Support Traits Depot' feature for fstat command 

#2535863 (Job #115952)
    Raised distinct exceptions for Server Resource Pressure commands

#2532392, #2536740	(Job #117017)
    Added support for --viewmatch argument in streams command

Updates in 2023.1 (2023.1/2512805) (2023/11/01)

#2497593, #2509668, #2502386 (Job #116934)
    Added support for the updated client spec in the 2023.1 Helix Core
    server release.

Updates in 2022.2 (2022.2/2444480) (2023/05/23)

#2435337 (Job #114238)
    Enhanced functionality of p4 print command with the addition of
    --offset and --size options.

#2426294 (Job #114313)
    Added support for 'MaxMemory' in the group spec.

#2439567, #2443196 (Job #114313)
    Added support for 'Components' in the stream spec.	  

Updates in 2022.1 Patch 2 (2022.1/2423241) (2023/03/28)

#2421117 (Job #112706)
    Fixed a bug where P4Java failed to update the sync time in db.have
    during a sync operation

#2409816 (Job #113999)
    Fixed a bug in decoding UTF-16 encoded files, which leads to file 
    corruption

#2369664 (Job #115104)
    Fixed a bug where using Metadata class for version information did not
    return a result.

Updates in 2022.1 Patch 1 (2023/01/12)

#2390507 (Job #113889)
    Syncing large files could produce corrupted client files larger than
    the expected size. Compressed files (binary or +C) are now properly
    decompressed. When writing converted bytes, we reset the temp buffer for
    compressed data and not close.

#2389019 (Job #113888)
    Syncing +x files will now always set the execute bit.

Updates in 2022.1 (2022/09/29)

#2345331 (Job #111078)
    Added support to uncompress the compressed files received from server

#2325394 (Job #111560)
     Added functionality to remove file revision attributes

#2322763 (Job #110629)
    Added support for special characters (@, %, # and *) in the file spec 
    builder by adding  ‘makeFileSpecListSpecialChars’ method

#2328997, #2330279 (Job #110207)
    Fixed a bug where sync of unicode files with bad charset was causing 
    corrupt files on the workspace without throwing an error

#2346483 (Job #109218)
    Fixed a bug where moves with an overlap between source and target 
    file/directory names raised an error.

#2333818 (Job #112005)
    Fixed a bug where unending sync operation was being caused when the 
    client compression option was set

    With this release we have migrated P4Java build from from Maven to 
    Gradle using Gradle wrapper 7.5

Updates in 2021.2 Patch 5

#2299942 (Job #108736)
    P4TRUST is no longer required for SSL connections where the server
    provides a certificate that's not self-signed and the certificate 
    chain can be verified by the client.  If verified, P4TRUST is 
    not required.
    
    The default java truststore is used unless you specify an 
    alternative truststore with java system properties
    javax.net.ssl.trustStore and javax.net.ssl.trustStorePassword
    
    Chain Validation can be disabled using p4java property 
    secureClientCertValidate set to 0 which does P4TRUST only.
    Setting to 2 will skip Chain validation and will ensure
    the server certificates' subject or subject alternate names
    match the hostname in the server URI.  The default of 1 will 
    validate the chain.  Both 1 and 2 fallback to P4TRUST if
    the chain cannot be validated.
    
    Fingerprints will now read and write the hostname in
    addition to the IP in the P4TRUST file.  Set the p4java property
    secureClientTrustName to 0 to only write the IP.  The default of
    1 writes entries for both the IP and hostname.  A value of 2
    will only write the hostname.   A matching fingerprint for either
    the IP or hostname will establish trust.

Updates in 2021.2 Patch 4

#2286431 (Job #099302)
    Fixed parallel sync authetication issue on case insensitive servers.
    Fixes JENKINS-48525 and JENKINS-68104.

Updates in 2021.2 Patch 3

#2277193 (Job #108577)
    Fixed parallel sync batchsize.

#2277668 (Job #110201)
    Parallel sync now passes charset to parallel threads.

Updates in 2021.2 Patch 2

#2263992 (Job #109211)
    Fixed how view mappings are parsed in label spec.

#2268314 (Job #108842)
    Reconcile of unchanged UTF17-LE files, no longer opens them for edit.

#2268017 (Job #105306)
    Fixed reconcile of paths with mix of slashes.

#2269716 (Job #110044)
    Login no longer throws exception when connected to a broker.

Updates in 2021.2 Patch 1

#2239495 (Job #109385)
    Supporting ticket + P4PASSWD in P4Java (ClientCrypto update with token2)

Changes in 2021.2

#2217804 (Job #109139)
    Update RPC API Server version to 91 (2021.2)

#2218345 (Job #107180)
    Added support for comments in Stream spec ViewMap.

#2215800 (Job #108303)
    Added Stream property to the Changelist spec.

#2231817 (Job #086112)
    Fixed a bug where sending commands to an Edge server
    that would require updates to the Commit server fail
    if the commit and edge tickets are different.

#2215800 (Job #109140)
    Added p4 streamcmds:
    p4 stream edit:
        Implemented via EditFileOptions.java,
        option editStreamSpec = "-So",
        this option will add opened Stream to changelist.

    p4 stream parentview:
        Added setStreamParentView(IStreamSummary.ParentView parentView),
        it will change the ParentView field
        and put it in the default changelist,
        ready for submit.

    p4 stream resolve:
        Implemented via ResolveFilesAutoOptions,
        option resolveStreamSpec = "-So".

    p4 stream revert:
        Implemented via RevertFilesOptions,
        options revertStreamSpec = "-So"
        and revertFileList = "-Si".

    p4 streamlog:
        New command, added Streamlog class.

#2211045 (Job #109141)
    Added MaxOpenFiles field to the Group spec.

Updates in 2021.1 Patch 1

#2191638 (Job #108308)
    Added parentview field to the Stream spec.

#2200941 (Job #108358)
    Added mergeany/mergedown options to the Stream spec.

#2200969 (Job #108391)
    Added ExtensionSummary class to improve handling of 
    p4 extension --list command.

Changes in 2021.1

#2152664 (Job #107179)
    Added support for p4 undo command.

#2152871 (Job #059080)
    Added support for p4 license command.

#2162308 (Job #107175)
    Added support for p4 extension command.

#2153946 (Job #107230)
    Added support for all p4 depots command arguments.

#1979275 (CVE-2021-29425)
    Upgraded apache commons-io library to 2.11.0.

Updates in 2020.1

#1997582 (Job #103444)
    null check on setType method in StreamSummary.

#1987725 #1988418 (Job #103182)
    Parse String or Integer values for HEADCHANGE and CHANGE in ExtendedFileSpec.

#1987752 #1987754 (Job #103185)
    Add lists for OTHER_(ACTION/CHANGE/OPEN) back into ExtendedFileSpec.

Changes in 2020.1

#1986688 (Job #103147)
    Update RPC API Server version to 88 (2020.1)

#1984234 (Job #103013)
    Update SSL to TLSv1.2.

#1975792 (Job #101710)
    Add flag support for p4 streams -F "Name=..."

#1982798 (Job #100914)
    Support for custom Stream specs

#1980693 (Job #101387)
    Performance improvement for ExtendedFileSpec

#1979275 (Job #085207)
    P4IGNORE multi-level directory support. 

#1891536 (Job #100727) 
    Support for reconcile -t flag. job. P4JAVA-1279.

Updates in 2019.1

#1938844 (Job #101882)
    Fix for ipaddr setting not being set in RPC packet.

#1938163 (Job #101821)
    Make MapTable::Check() public in the MapAPI classes.

#1888951 (Job #100707)
    Support temporary workspaces using client -x flag

#1888155 (Job #100689)
    Fixed connection issue when p4charset is set to null.

#1877890, #1879014  (Job #100476)
    Added single sign on support into P4Java.

#1882700 (Job #100498)
    Support for P4CLIENTPATH - P4JAVA-1270   
        
#1883243 (Job #100498)
    Add support for filesys.restictsymlinks

#1883168 (Job #098414)
    CopyFilesOptions with -f flag 

Changes in 2019.1

#1867087, #1872532 (Job #100139)
    Fix for symlink writable issue which fixes the can't clobber writable file error.

#1868735, #1870310 (Job #092308)
    Fix for missing BOM when syncing unicode file w/p4charset=utf8-bom.

#1868285, #1868848, #1870310, #1871475 (Job #095794)
    Resolved symlink open for edit issue when using reconcile.

#1826912, #1826262, #1825761, #1824484 (Job #099244)
    Fix for symlink permission issue and support for temp file rename and move

#1822014 (Job #099164)
    Support Ditto '&' mappings in client view.

#1821933 (Job #099149)
    Resolve symlink detection issue when using reconcile.

#1815000 (Job #099165)
    Support reconcile streaming functionality

#1796426 (Job #092896)
    Support Server API level 81
    
#1722678 (Job #055900)
    Java client MapApi support with new IClient:localWhere() command.
    
#1800490 (Job #097819)
    Use correct delegator for getShelvedFiles command

Changes in 2018.1

#1637342 (Job #094427)
    Support for second factor authentication (login2).

#1635988 (Job #094697)
     Fix Windows reconcile edit digest check on 'UTF8' filetype.

#1634431 (Job #084939)
    Implement file modtime check in client-side reconcile.

Changes in 2017.2

#1633840 (Job #094658)
    Fixed 'shiftjis' bug nonNull -> isNull.
    
#1622239 (Job #094389)
	Cleanup symlink files after a reconcile -w.. 

#1600799 (Job #093734)
    Throw warning messages from execStreamCmd as RequestExceptions (e.g. p4 print)
    
#1596014 (Job #093755)
	Allow getJob with empty name.  Used to fetch an empty job spec. 

#1578376 (Job #093036)
    Update Client Spec to support 'ChangeView' and 'Backup'.

#1577417 (Job #092995)
    Changed Property Sequence field from int to String to allow 'none' from Swarm.

#1560334 (Job #092589)
    Add new method with repo option for getCommitObject(String sha, String repo).

#1549994 (Job #092462)
    Add Max limits for getChangelistFiles and getShelvedFiles.

#1533680, #1534733 (Job #092122)
    Files of Perforce types utf16 and unicode now successfully sync.

#1531542 (Job #092080)
	Fixed authentication for parallel threads on edge/commit servers.

#1528556 (Job #092030)
	Fixed missing callback issue for parallel transmit for regular sync

#1509454 (Job #084396)
	Support for parallel sync in the Helix Versioning Engine 2017.1

#1510880 (Job #091429)
	P4Java implementation of 'p4 list'
	
#1510174 (Job #091430)
	Support 'Type' field in client spec for: readonly/partitioned/graph
	
#1510150 (Job #090601)
	Added Integrate Options for -Or -Ob and -2

Changes in 2017.1

* Support for graph depot in the Helix Versioning Engine 2017.1 
  to serve P4Jenkins 2017.1

Changes in 2016.1

* The JAR file no longer includes all its dependencies in a single
  large JAR file, so some third party libraries (such as Apache 
  Commons) will now be listed as external dependencies.
  
* Parts of the API have been refactored, notably the implementation
  classes behind IServer. As part of this, the following methods
  have been deprecated:
  * The Changelist constructor for IOptionsServer
  * Server.handleFileReturn
  * FileRevisionData.getRevisionIntegrationData
  * IFileRevisionData.getRevisionIntegtrationData

Bugs fixed in 2016.1

#1498327 (Job #90814)
    Fix locking issue with concurrent read and write access to users 
    ticket file.

#1433571 (Job #73675)
    Fixed issue where unable to submit file that only contains a 
    space.

#1462223 (Job #81399)
    Fix +x not being synced on Linux filesystems.

#1435627 (Job #84577)
    Fix for exception messages being obscured.

#1431937 (Job #85433)
    Many fixes for UTF16 encoding issues. How P4Java handles Unicode
    text has been changed quite a bit, and there are user facing issues
    which may have required a work around before which no longer do.

#1431937 (Job #86058)
    Fixed utf8 files being corrupted on adding carriage return.
    
#1460161 (Job #86035, #86034)
    Fix support for files greater than 2GB in size.
    
#1432900 (Job #86648)
    Fixed problem where UTF characters are detected as being a
    binary file rather than text file.
    
#1464885 (Job #89313)
    Fixed handling of text files based on line endings.
    
#1480031 (Job #89581)
    Fixed problem where results of p4 groups command was only
    being partially populated.
    
#1479581 (Job #89596)
    Fix for when update of a job object can be ignored.

Bugs fixed in 2015.2

#1365094 (Job #85473) Fix an issue when syncing files with file type 'unicode+x'.

#1308053 (Job #83624)
    Fixed a potential problem where busy concurrent p4 login and
    p4 logout commands could wipe out (loose) tickets in the
    P4TICKETFILE file by creating a shadow P4TICKETFILE lock
    (".lck") file.

#1305655 (Job #80437)
    Fixed an issue where large files (size > 2GB) are being
    truncated when synced on the Windows plaform.

#1305257 (Job #80413)
    Fixed an issue when syncing files with size > 2GB (number of
    bytes > java.lang.Integer.MAX_VALUE).

#1244354 (Job #81080)
    Fixed an issue with P4Java connecting and authenticating to
    a Perforce server with (man-in-middle) security configurable
    'net.mimcheck' set to value >= 4.

#1237901 (Job #80389)
    Fixed a file corruption issue with P4Java shelving/unshelving
    of utf16-le files in the Windows environment.

#1244455 (Job #70733)
    Fixed a potential data loss problem with P4Java's handling of
    protections. P4Java now uses the innate ordering of Java List
    instead of explicitly setting the order of each protection entries.

#1234279 (Job #67229)
    Fixed an issue where the 'integrate' command fails if the current
    client set on P4Java is not "myclient" when executing myclient's
    integrateFiles() methhod.

#1222114 (Job #62825)
    Fixed an issue where the 'shelve' command fails if the current
    client set on P4Java is not "myclient" when executing myclient's
    shelveChangelist() methhod.

Minor new functionality in 2015.2

#1310414 (Job #83909)
    Add support for "SpecMap" in the depot spec. For spec depots,
    the optional description of which specs should be saved, as
    one or more patterns. For example, "-//spec/client/*_tmp*".

#1310411 (Job #83908)
    Add support for "tangent" depot type. It defines a read-only
    location which holds tangents created by the 'fetch -t' command.
    The tangent depot named 'tangent' is automatically created by
    'fetch -t' if one does not already exist.

#1310141 (Job #83907)
    Added support for the "StreamDepth" field in the depot spec.
    For stream depots, the optional depth to be used for stream
    paths in the depot, where depth equates to the number of
    slashes following the depot name of a stream. This field is
    referenced when streams are being created. The default is '1',
    matching the traditional stream name. This value may not be
    updated once streams or archive data exist within the depot.

#1243317 (Job #80744)
    Added support for stream path type 'import+'. It is the same
    as 'import' except that files can be submitted to the import
    path. This feature requires Perforce server version >= 2014.2.

Bugs fixed in 2015.1

#1208529 (Job #79753)
    Updated the P4Java 2015.1 default client API level to 78,
    representing the "2015.1 capabilities".

#1206466 (Job #79502)
    Fixed an issue with child process I/O streams not properly
    closing when RPC socket pool is enabled (pool size > 0) and
    P4Java is starting new 'RSH' mode Perforce server processes.

#1207366 (Job #77850)
    Fixed an issue with 'utf16+x' files synced as 'UTF-8' with
    UNIX line endings.

#1206436 (Job #74785)
    Fixed an issue where utf16 little endian files synced as big
    endian in a little endian client platform. When utf16 files
    are written to a client, they are written with a BOM in client
    byte order. (See 'p4 help filetypes').

#1059603 (Job #78811)
    Fixed issue where Perforce depot archive file content for a
    symlink was missing a '\n' when file type is 'symlink+F' when
    using P4Java for submit.

#1054452 (Job #78085)
    Changed 'noclient' to '____CLIENT_UNSET____' as default unset
    client name.


#981766 (Job #74948, 75630)
    Fixed an issue where the execution bits are not set correctly
    when syncing files. The 'p4' client sets the Owner/Group/World
    bits.

Major new functionality in 2015.1

#1001469 (Job #34706)
    Added support for starting a 'RSH' mode Perforce server from
    P4Java. This feature is known as the "Perforce RSH hack". P4Java
    URI example: "p4jrsh:///path/to/p4d -r /tmp/p4droot -i --java".
    This feature requires Perforce server version 2015.1 or above.

#980238 (Job #76501, 76540)
    Added support for replacement fingerprint in an SSL connection.
    If a replacement fingerprint exists for a connection and the
    primary fingerprint does not match while the replacement
    fingerprint does, the replacement fingerprint will replace
    the primary. This corresponds to the 'p4 trust -r' option.

Minor new functionality in 2015.1

#1036870 (Job #78145)
    Implemented P4Java handling of 'login' and passed-in auth ticket
    in a Perforce cluster environment (i.e. "serverAddress = P4Cluster").

#1020252 (Job #77547)
    Added the 'checkModTime' option to ReconcileFilesOptions;
    used in conjunction with -e can be used to minimize costly
    digest computation on the client by checking file modification
    times before checking digests to determine if files have been
    modified outside of Perforce. This option correspond to the
    '-m' flag in the 'p4 reconcile' command.

#1013627 (Job #77517, 77476)
    Added the 'updateWorkspace' option to ReconcileFilesOptions;
    forces the workspace files to be updated to match the depot.
    This option correspond to the '-w' flag in the 'p4 reconcile'
    command.

Bugs fixed in 2014.1

#940015, 958821 (Job #74971)
    Fixed an issue where Label.isLocked() always returns false.
    This method pertains to the "locked/unlocked" label update
    option. Also, added a new method Label.isAutoReload() for
    the "autoreload/noautoreload" option.

#907023 (Job #74183)
    Fixed a problem where P4Java returns "file does not exist"
    messages when syncing deleted files. The solution is to bypass
    the delete operation if the file doesn't exist.

#873061 (Job #73266)
    Fixed an issue where P4Java does not capture output in local
    file syntax when running the 'p4 reconcile -l' command option.
    This option is set via the ReconcileFilesOptions.setLocalSyntax()
    method with 'true' as the input parameter value.

#872927 (Job #69493)
    Fixed an issue where the p4trust file cannot be set using the
    "trustPath" or the long form "com.perforce.p4java.trustPath"
    property when requesting an IOptionServer from the ServerFactory.

#854818 (Job #70533)
    Fixed a regression issue where the IFileSpec.getOriginalPath()
    returning null. Now, it will try to return the pseudo-type
    PathType.ORIGINAL path, if it is not null. Otherwise, it will
    return the PathType.CLIENT path.

#849483 (Job #71635)
    Fixed an issue where malformed exclude protection entries
    occurring when the depot paths with whitespace are quoted.
    The IOptionsServer.updateProtectionEntries() method corresponds
    to the 'p4 protect -i' command.

#842721 (Job #71340)
    Fixed an issue where unchanged large size files with Unicode
    chars showing as different on Windows using Perforce client
    charset 'utf8'. The IClient.getDiffFiles() method corresponds
    to the 'p4 diff -s<flag>' command.

#841016 (Job #72717)
    Fixed a permissions issue with the Perforce tickets file in
    the Windows environment.

#840491 (Job #72688)
    Fixed a problem with the IClient.reconcileFiles() method
    throwing an exception when file path contains whitespace.
    The MapEntry class requires double quotes to placed around
    file path with whitespace. This method corresponds to the
    'p4 reconcile' command.

#839020 (Job #72521)
    Fixed an issue with the Server.getFileContents() method
    returning null InputStream for non-existing file or revision.
    This method corresponds to the 'p4 print' command.

Major new functionality in 2014.1

#948217 (Job #71639)
    Added a new P4Java API method 'renameUser()' to
    IOptionsServer for completely renaming a user, modifying
    all database records which mention the user. This method
    corresponds to the 'p4 renameuser' command. This command
    requires 'super' access.

#876221 (Job #72273)
    Added support for automatically detect and setup P4Java's
    Perforce client charset when connected to an Unicode enabled
    Perforce server. The automatic client charset is provided by
    the JVM and OS platform. If Perforce doesn't support the
    detected client charset it will default to 'utf8'.

#851606 (Job #72689)
    Added a new P4Java API method 'getShelvedFiles()' to
    IOptionsServer for retrieving a list of shelved files
    from a pending change list. This method corresponds to
    the 'p4 describe -s -S <changelist>' command.

#848677 (Job #71702, 72794)
    Added new P4Java API methods 'getTriggerEntries()',
    'createTriggerEntries()' and 'updateTriggerEntries()'
    to IOptonsServer for retrieving and updating the Perforce
    triggers table. The methods correspond to the 'p4 triggers'
    command. This command requires 'super' access.

Minor new functionality in 2014.1

#949065 (Job #70485)
    Added the 'wipeAddFiles' option to RevertFilesOptions;
    causes files that are open for add to be deleted from the
    workspace when they are reverted. This option correspond to
    the '-w' flag in the 'p4 revert' command.

#944457 (Job #70486)
    Added the 'outputDifferFilesOnly' option to GetFileDiffsOptions;
    limits output to files that differ. This option correspond to
    the '-Od' flag in the 'p4 diff2' command.

#895748 (Job #71638)
    Added support for Greek character sets 'cp1253' (Windows
    Greek), 'cp737' (PC Greek), and 'iso8859-7' (Latin/Greek
    Alphabet).

#873818 (Job #59516)
    Added a new method 'getServerCalendar()' to IServerInfo
    for retrieving the Perforce server date as a Calendar
    object, with the server timezone related information.
    For examples, '2014/06/05 10:28:16 -0700 PDT' and
    '2014/06/05 17:10:53 -0700 Pacific Daylight Time'.

#852880 (Job #72336)
    Included the submitted 'time' in the FileSpec, accessible
    via the IFileSpec.getDate() method. The 'time' for each
    file is returned from the Perforce server when listing
    depot files using the IOptionsServer.getDepotFiles() method.
    This method corresponds to the 'p4 files' command.

Major new functionality in 2013.2

#674297 (Job #62361)
    Added a new P4Java API method 'getProtectionsTable()' to
    IOptionsServer for retrieving the Perforce protections table.
    This corresponds to the 'p4 protect -o' command option.
    Note that after protections are defined, the 'p4 protect'
    command requires 'super' access.

#677643 (Job #66386)
    Added a new P4Java API method 'submitShelvedChangelist()'
    to IClient for allowing the submit of a shelved changelist
    without transferring files or modifying the workspace.
    This corresponds to the 'p4 submit -e shelvedChange#'
    command option. Note that the shelved changelist must be
    owned by the person submitting the change, but the client
    may be different. No files may be open in any workspace
    at the same changeless number.

#689881 (Job #67365)
    Added a new P4Java API method 'getFileSizes()' to the
    IOptionsServer interface. This method will return a list
    of file sizes for one or more files in the depot. This
    corresponds to the 'p4 sizes' command.

#709742 (Job #68493)
    Added a new P4Java API method 'journalWait()' to the
    IOptionsServer interface. This method turns on/off the
    journal-wait. The client application can specify "noWait"
    (off) replication when using a forwarding replica or an
    edge server. This corresponds to the deep undoc
    'p4 journalwait [-i]' command.

Minor new functionality in 2013.2

#642703 (Job #66150)
    Added support for the 'IsUnloaded = 1' tagged output for
    the 'streams -U', 'clients -U' and 'labels -U' commands by
    implementing the isUnloaded() method on the IStreamSummary,
    IClientSummary and ILabelSummary interfaces.

#656821 (Job #66779)
    Upgraded the JZlib compression library from version 1.1.1 to
    version 1.1.2. A list of changes can be viewed from the JZlib
    project website: http://www.jcraft.com/jzlib/ChangeLog

#659272 (Job #66882)
    Added a method in the SymbolicLinkHelper class to get the last
    modified time of symlinks with non-existing targets. Note that
    it only works with symlink capable Java versions and systems.

#662206 (Job #62832)
    Added the 'shortOutput' option to OpenedFilesOptions; produces
    optimized output when used with the -a (all clients) option.
    This option corresponds to the '-s' flag in the 'p4 opened'
    command.

#671504 (Job #59611)
    Added support in ExtendedFileSpec for capturing propagating
    attributes and attribute types from the 'fstat -Oa' command
    output.

#672814 (Job #59617)
    Added the 'groupName', 'userName' and 'ownerName' options to
    GetUserGroupsOptions; indicating that the 'name' argument is
    a(n) group/user/owner. These options correspond to the '-g',
    '-u' and '-o' flags in the 'p4 groups' command.

#673539 (Job #59624)
    Added the 'suppressHeader' and 'showBinaryContent' options
    to GetFileAnnotationsOptions; suppresses the one-line header
    and displays the content of binary files. These options
    correspond to the '-q' and '-t' flags in the 'p4 annotate'
    command.

Bugs fixed in 2013.2

#648450 (Job #66455)
    Fixed an issue with P4Java not being able to add symlinks
    due to the missing 'xfiles' RPC protocol information. This
    occurs when the user is using a RPC socket connections pool.

#649176 (Job #66501)
    Fixed an issue with P4Java not being able to add symlinks
    pointing to directories. P4Java mistakenly detecting these
    symlinks as real directories.

#657580 (Job #66811)
    Fixed an issue with P4Java not being able to add/submit
    symlinks with non-existing targets.

#666385 (Job #67072)
    Fixed an issue with P4Java using the wrong last modified
    time when adding a symlink that points to a directory. It
    was wrongly using the symlink target's last modified time.

#670576 (Job #67305)
    Properly allowed P4Java's RPC sockets to be configured with
    user defined properties first before connecting to the server.

#676527 (Job #67386)
    Updated P4Java to use a lowercase username to save and
    retrieve the auth ticket when connected to a case insensitive
    Perforce server.

#678044 (Job #67571)
    Fixed an issue with P4Java when running 'resolve -at' of a
    symlink that points to a null reference (non-existing target).

#693440 (Job #68151)
    Fixed an issue where FileAction.UNKNOWN.toString() throws a
    P4JavaError (name / ordinal mismatch).

#696011 (Job #68281)
    Fixed an issue with P4Java when syncing a text file revision
    with the current local head revision as a symlink pointing
    to a non-existing target.

#709753 (Job #68751)
    Fixed an issue with P4Java where binary files are corrupted
    in the Windows environment when sync is forced and the files
    are already in the have list.

#717231 (Job #68974)
    Fixed an issue with the 'diff -sa' command (IClient.getDiffFiles())
    returning results (filespecs), even though the content of the files
    were not modified. This happens when using a client workspace with
    the "LineEnd: win" spec running on the Mac/Linux/UNIX platforms.

#748489 (Job #69733)
    Fixed an issue with the IClient.getDiffFiles() method returning
    wrong diff results when operating on 'utf8-bom' encoded files
    on the Windows platforms.

Major new functionality in 2013.1

#546744 (Job #61136)
    Added support for unpacking the AppleSingle file format.
    This corresponds to the Perforce 'apple' file type. When
    syncing 'apple' type files, P4Java will extract the data
    fork and resource fork into two separate files. The data
    file will retain the original file name, and the resource
    file will have a '%' sign prefix. Note that the user must
    stitch the data fork and resource fork back to an AppleSingle
    file before submitting changes back to the Perforce server.

#548578 (Job #61060, 61048)
    Added support for connecting to an IPv6 server address URI.
    IPv6 server addresses need to be encapsulated within square
    brackets (i.e. 'p4java://[fe80:0:0:0:0:0:c0a8:108]:1666'),
    follow by a ':' and a port number. Auth tickets and trusted
    fingerprints also support the IPv6 server address format.

#557503 (Job #59734)
    Added the ability to cancel a long running command in P4Java
    (i.e. syncing many files or a large file). The command can
    be cancelled by returning false in the IStreamingCallback's
    handleResult(...) method.

#572509 (Job #61531)
    Added support for "spec -o" commands ('client -o', etc.).
    This feature can only be used with the raw "exec" methods
    (execMapCmd(), execStreamCmd(), etc.) of the IServer and
    IOptionsServer interfaces. The user must pass to those
    raw methods an 'inMap' as parameter with an 'useTags' map
    entry key and its value set to 'no'. The returning result
    will be the non-tagged output of the requested spec.

#602176 (Job #64162)
    Added new methods IOptionsServer.get/setTicketsFilePath(...)
    and IOptionsServer.get/setTrustFilePath(...) for getting
    and setting the auth tickets file and the trust file paths.

#621534 (Job #65076)
    Added new P4Java API methods to use the list data structure
    to store the result maps instead of array. Refactored all
    affected P4Java code to use these new methods: execMapCmdList,
    execInputStringMapCmdList and execQuietMapCmdList.

#629318 (Job #65303)
    Added a new low-level IFilterCallback interface that allows
    developers to decide which key/value pairs should be skipped
    from going into the result maps. Currently, the IFilterCallback
    interface is supported as a parameter in the following P4Java
    public API methods: IOptionsServer.execMapCmdList(�) and
    IOptionsServer.execInputStringMapCmdList(�).

#639161 (Job #59605)
    Implemented the 'p4 property' command. Add, delete, or list
    property values in the Perforce server. The Perforce server
    does not directly use property values. It provides storage
    of property values for use by applications that wish to
    persistently store their configuration settings and other
    property data in the Perforce server.

#649812 (Job #66524)
    Added proper handling of P4Java's Perforce extended charsets
    if they are not loaded in the VM's bootstrap classpath. For
    example, the P4Java JAR file is inside a WAR deployed in a
    web app container like Jetty, Tomcat, etc.

Minor new functionality in 2013.1

#529831 (Job #59317, 38737)
    Added the ability to set socket performance preferences by
    passing a property to the ServerFactory when requesting an
    IOptionsServer object. The property key can be either the
    short form "sockPerfPrefs" or the long form
    "com.perforce.p4java.rpc.sockPerfPrefs". The property value
    should be exactly three integers (i.e. "1, 2, 0") as a string,
    separated by commas. The default is set to the relative importance
    of short connection time, low latency, and high bandwidth.

#528658 (Job #59081, 38737)
    Upgraded the JZlib compression library from version 1.0.7 to
    version 1.1.1. A list of changes can be viewed from the JZlib
    project website: http://www.jcraft.com/jzlib/ChangeLog

#528663 (Job #59114, 38737)
    Updated P4Java to use JZlib's pure Java implementation of the
    CRC32 checksum. This avoids the basic Java CRC32's JNI overhead
    for certain uses of checksumming where many small pieces of data
    are checksummed in succession.

#529232 (Job #59116, 38737)
    Updated P4Java to use BufferedOutputStream to improve file
    writing performance during the 'sync' command.

#529227 (Job #59115, 38737)
    Updated P4Java to use BufferedInputStream to improve RPC socket
    stream reading performance.

#559385 (Job #59637)
    Added the 'quiet' option to CopyFilesOptions, IntegrateFilesOptions
    and MergeFilesOptions; corresponds to the "-q" flag in 'p4 copy',
    'p4 integrate' and 'p4 merge' commands. If true, suppresses the
    normal informational file list messages from being sent.

#565178 (Job #59638)
    Added the ability to set the 'quiet' mode "p4 -q <command>" RPC
    protocol option to suppress all info-level output client messages.
    To enable protocol 'quite' mode set the "quietMode" or the long
    form "com.perforce.p4java.quietMode" property to "true" (anything)
    when requesting an IOptionServer from the ServerFactory.

#565975 (Job #59627)
    Added support for the 'resolveType' field of the 'p4 fstat -Or'
    command's output.

#566909 (Job #59625, 59632)
    Added support for the 'baseParent' field of the 'p4 streams'
    command's tagged or/and filtered output.

#581288 (Job #62715)
    Added the 'nameFilters' option to GetCountersOptions and GetKeysOptions;
    corresponding to the '-e[nameFilter] -e[nameFilter] -e[nameFilter] ...'
    flags in the 'p4 counters' and 'p4 keys' commands. This option handles
    multiple nameFilter flags as arguments to the aforementioned commands.

#591416 (Job #62697)
    Added the 'force' option to ChangelistOptions; corresponds to
    the "-f" flag in 'p4 change' command. If true, it can force display
    of the 'Description' field in a restricted changelist using the
    IOptionsServer.getChangelist(int id, ChangelistOptions opts) method.

#596795 (Job #63310)
    Added support for force delete of another user's pending changelist
    using the IOptionsServer.getChangelist(int id, ChangelistOptions opts)
    method with the 'force' option set to true in ChangelistOptions. This
    option corresponds to the "-f" flag in 'p4 change' command.

#639392 (Job #66055)
    Added the 'stream' option to UnloadOptions and ReloadOptions;
    corresponds to the "-s stream" flag in 'p4 unload' and 'p4 reload'
    commands. If set, it unloads/reloads the specified task stream.
    Also, added the 'locked' option to UnloadOptions; corresponds to
    the "-L" flag in the 'p4 unload' command. If true, it specifies
    that the client, label, or task stream should be unloaded even if
    it is locked.

Bugs fixed in 2013.1

#544735 (Job #60527)
    Fixed an issue with high-ascii client names (i.e. umlaut '�')
    when running the 'where' command against a non-unicode server.

#543339 (Job #60376)
    Added handling of the 'replaced' file action. This file action
    occurs when replacing a file with the same name, that was mapped
    from a different source.

#560914 (Job #61935)
    Fixed an issue with text file (high-ascii chars in name or path)
    identified as a symlink during an add operation.

#551070 (Job #60128)
    Deprecated ZeroConf support in P4Java. The server and proxy no
    longer support the Zeroconf server registration protocol. This
    takes effect on Perforce server version 2013.1 and above.

#615005 (Job #64015)
    Fixed a problem with user auth tickets sharing a singleton storage
    when the same user is used in multiple RPC connections logging in
    and out frequently.

#627400 (Job #65464)
    Fixed a possible memory leak by removing the File.deleteOnExit()
    call in P4Java. Java accumulates the file path information in
    memory every time the File.deleteOnExit() call is made. If the
    the Java program stays alive for a long period of time, the
    memory usage will grow.

#627608 (Job #65305)
    Fixed an issue with the AuthTicketsHelper throwing an exception
    (FileNotFoundException) when trying to retrieve auth tickets
    from an auth tickets file that does not exist.

#633427 (Job #65872)
    Fixed a problem with P4Java not properly handling (save/change)
    passwords with high-ascii/unicode chars (i.e. umlaut '�').

#655384 (Job #66260)
    Fixed an issue with P4Java's Perforce file type detection
    (infer file type by content) mistakenly detected 'utf16'
    (unicode) files as binary.

#645046 (Job #66294)
    Fixed an issue with P4Java not properly converting the 'diff2'
    command header output to the client's charset.

#670224 (Job #67176)
    Fixed an issue with P4Java's login method returning the wrong
    auth ticket requested for a specified host IP address. This
    corresponds to the 'p4 login -h<host>' command option.

Major new functionality in 2012.3

#487658 (Job #38013, 34097, 59186)
    Added support for symbolic links with JDK 7 running on UNIX/Linux
    (UNIX-like) operating systems and newer versions of Microsoft
    Windows (Windows Vista or above). Microsoft has hard links
    support as of Windows 2000. However, UNIX-like symbolic links
    are only supported as of Windows Vista.

#494418 (Job #57603)
    Added support for progress indicators (p4 -I <command>). This
    feature is supported by Perforce server 2012.2 or higher. To
    enable 'p4 -I' set the "com.perforce.p4java.enableProgress"
    or "enableProgress" property to "true" (or anything) when
    requesting an IOptionServer from the ServerFactory class (as
    the Properties 'props' parameter pass to the getOptionsServer()
    method). This feature makes sense to be used with the "raw"
    IServer.execStreamingMapCommand() method. This streaming method
    takes a callback handler and continuously report progress during
    the execution of a command. Note that currently only some commands
    return progress indicators.

#495802 (Job #58105, 56531)
    Added support for unload and reload clients and labels. Implemented
    the 'p4 unload' and 'p4 reload' commands. Added the '-U' option for
    'p4 clients' and 'p4 labels'. By default, users can only unload and
    reload their own clients or labels.  The '-f' flag requires 'admin'
    access, which is granted by 'p4 protect'.

#502033 (Job #40480)
    Added the IOptionsServer.getStreamingExportRecords(...) method.
    This method returns each exported journal or checkpoint
    record as it comes in from the Perforce server using the
    IStreamingCallback handleResult method.

#505864 (Job #58523)
    Added support for the 'p4 populate' command as the
    populateFiles(...) method on IOptionsServer. This method
    branches a set of files (the 'source') into another depot
    location (the 'target') in a single step.  The new files
    are created immediately, without requiring a 'p4 submit'
    or a client workspace.

#519075 (Job #59388)
    Added new IClient.sync(...) and IChangelist.submit(...) methods
    with IStreamingCallback. When progress indicators are turned on
    (set the "com.perforce.p4java.enableProgress" or "enableProgress"
    property to "true" when requesting an IOptionServer from
    the ServerFactory), the results are sent to the user via
    IStreamingCallback.handleResult(...), as each comes in from
    the server.

#521298 (Job #59434)
    Added support for streaming back incremental progress details
    of syncing and submitting files. The file data chunks info
    (bytes written so far...) will be sent back to the user via
    IStreamingCallback.handleResult(...).  This feature requires
    the progress indicators flag (p4 -I) to be on, set the
    "enableProgress" or "com.perforce.p4java.enableProgress"
    property to "true" when you request an IOptionServer from
    the ServerFactory.

#525729 (Job #59814)
    Added in-memory storage for auth tickets and fingerprints.
    By default, P4Java uses files to store auth tickets and SSL
    connection fingerprints. To turn on in-memory storage of auth
    tickets and fingerprints set the "useAuthMemoryStore" or the
    long form "com.perforce.p4java.useAuthMemoryStore" property
    to "true" (or anything) when requesting an IOptionServer from
    the ServerFactory.

Minor new functionality in 2012.3

#488202 (Job #50343)
    Automatically set the user's auth ticket (if available) when
    calling the Server.setUserName(String userName) method. Unset
    the user's auth ticket after logging out. This is useful when
    you are using (switching between) multiple Perforce users
    within the same instance of P4Java.

#499857 (Job #50047)
    Added the 'dontAnnotateFiles' option to the GetFileContentsOptions
    class.  If true, don't append revision specifiers (# and @) to
    the filespecs (Parameters.processParameters(...)). By default
    the filespecs passed to IOptionsServer.getFileContents(...)
    would get revisions appended to them during parameter processing.
    Note that this is not a standard option for the 'p4 print' command.

Bugs fixed in 2012.3

#491077 (Job #57711)
    Fixed an issue with 'p4ticketsxxxx.txt' files accumulating in
    temporary directory (Java system property "java.io.tmpdir").
    Delete the temp tickets file immediately after usage. If the
    rename (move) operation is successful there is no need to
    delete the temp tickets file (it is already moved to the
    target file). If it is copied to the target file P4Java
    will delete it after the copy operation. If the immediate
    deletion fails P4Java will call deleteOnExit() as a fallback.
    Note that if the temp tickets file is locked (for some reason)
    P4Java will not be able to delete it.

#491101 (Job #57797)
    Fixed a possible issue with fingerprints files accumulating in
    temporary directory (Java system property "java.io.tmpdir").
    Delete the temp fingerprints trust file immediately after
    usage, and call deleteOnExit() as a fallback.

#497015 (Job #55040)
    Added handling of the 'types' status returning from a 'diff2'
    command.  This fixes the problem with Server.getFileDiffs()
    returning an IFileDiffs record with a status of "null" when
    two identical files (revisions) differ only by filetype.

#497448 (Job #49896)
    Fixed an issue with the Label.updateOnServer() method raises
    exception with message "label not associated with any Perforce
    server", even though the user had supplied one via the
    Label.newLabel(...) method. Attaching the IServer to the
    newly created Label inside the Label.newLabel(...) method
    resolved this problem.

#516088 (Job #59253)
    Fixed an issue with parsing exotic client view mappings
    (i.e. file paths with double quotes within, etc.).

#520350 (Job #59485)
    Fixed the handling of passwords containing valid whitespace
    characters (i.e. spaces or tabs) at the beginning or end.

#524943 (Job #59813)
    Fixed concurrency issues with multithreaded P4Java access
    to the Perforce tickets and fingerprints files. This fix
    only applies to the same instance of the JVM.

#531260 (Job #59311)
    Fixed an intermittent ConnectionException issue with P4Java
    talking to a Perforce broker using an instance of the NTS
    (non-thread-safe) version of the P4Java RPC implementation.

#537649 (Job #36721)
    Fixed an issue with syncing Japanese files containing special
    double-byte characters. Updated P4Java to use the Microsoft
    code page 932 charset implementation (superset of shiftjis).

#538849 (Job #60524, 59311)
    Fixed a P4Java RPC communication timeout issue when talking
    to a P4Broker sitting between P4Java and a Perforce server.

#549353 (Job #61402, 60798)
    Added support for the protocol level "app" tag. The user can
    set the value for the 'app' protocol tag by passing a property
    to the ServerFactory when requesting an IOptionsServer object.
    The property key can be either the short form "applicationName"
    or the long form "com.perforce.p4java.rpc.applicationName".

#575950 (Job #62513)
    Updated P4Java to handle multiple (sometimes different) auth
    tickets while connected to a replica. Note there are limitations
    using a replica server versus the master server directly. Please
    see the "Perforce Replication" documentation for more details.

#616470 (Job #64875)
    Fixed a regression bug where P4Java is not automatically loading
    the user's auth ticket from the tickets file.

#621705 (Job #65168)
    Fixed an issue with P4Java not updating the password correctly
    when it is preceded with a deletion of the current password.

Major new functionality in 2012.2

#467995 (Job #54780)
    Implemented the 'p4 reconcile' command. Open files for add,
    delete, and/or edit to reconcile client with workspace changes
    made outside of Perforce (Perforce server 2012.1 or higher).

#483886 (Job #57185)
    Implemented the 'p4 duplicate' command. Duplicate revisions with
    integration history (unsupported). This command requires 'admin'
    access granted by 'p4 protect'.

#470782 (Job #43626)
    Implemented the 'p4 review' command. Lists changelists that
    have not been reviewed before, as tracked by the specified
    counter.

Minor new functionality in 2012.2

#469441 (Job #55297)
    Added conditional checking for password not set for the user
    during login. If the passed-in password is not null/empty and
    the server return message indicates password not set (login not
    required) for the user, then throw an AccessException.

#474051 (Job #51848)
    Added a new IOptionsServer.getServerProcesses method that takes
    a GetServerProcessesOptions parameter. This method gives more
    information about Perforce server processes for monitoring.

#473880 (Job #55600)
    Added the skipFile option to ResolveFilesAutoOptions; corresponds
    to the '-s' option in p4 resolve. This option indicates to 'skip
    this file' during resolve.

#473721 (Job #44095)
    Passed more info to the IProgressCallback.tick() method. Added
    support for sync (similar to the 'p4 sync' standard output).
    Also, included the 'totalFileSize' and 'totalFileCount' info.

Major new functionality in 2012.1

#401481 (Job #36273, 51219)
    Implemented the 'p4 passwd' command with support for password
    change on security level 2 or 3 Perforce servers. Added support
    for passwords longer than 16 characters; cease truncating
    passwords to 16 bytes (Perforce server 2011.1 or higher)

#403123 (Job #51534)
    Added SSL support for encrypted secure connections to SSL
    enabled Perforce servers. The only change to make a secure
    connection using P4Java is to append 'ssl' at the end of the
    P4Java protocol (i.e. 'p4javassl://perforce:1667').
    * Check the "Known Limitations" for possible SSL issues.

#428335 (Job #53040)
    Added support for 'p4 trust' command and public key fingerprint
    checking for SSL connections to a secure Perforce server. For a
    new connection or mismatched key the user must run the 'addTrust'
    methods to establish trust (again).

#410387 (Job #51892)
    Added the ability to ignore files for the 'p4 add' command.
    For each 'add' file, P4Java checks the patterns defined in
    the 'P4IGNORE' files along the 'add' file's path to determine
    whether the 'add' file should be ignored or not.

#416539 (Job #52418, 40151, 39722)
    Updated the NTS (non-thread-safe) version of the P4Java RPC
    implementation to fully support the 'p4jrpcnts' protocol.
    This implementation allows multiple commands to be excuted
    over the same RPC connection. To use this implementation,
    simply connect to the Perforce server using the 'p4jrpcnts'
    protocol (i.e. 'p4jrpcnts://perforce:1666'). See the Javadoc
    of the 'NtsServerImpl' class for proper 'safe' usage.

#437207 (Job #41786, 53896)
    Added 'p4 -Ztrack' support for 'track' information on what
    tables a command is accessing, and implicitly locking. This
    feature is supported at various lower level "raw" IServer
    methods (i.e. execMapCmd()). To enable 'Ztrack' set the
    "com.perforce.p4java.enableTracking" or "enableTracking"
    property to "true" (or anything) when requesting an
    IOptionServer from the ServerFactory class (as the Properties
    'props' parameter pass to the getOptionsServer() method).

Minor new functionality in 2012.1

#467236 (Job #56219)
    Added the addIfAdmin option to UpdateUserGroupOptions; corresponds
    to the '-A' option in p4 group. This enables a user with 'admin'
    access to add a new group. Existing groups may not be modified
    when this flag is used.

#403936 (Job #51803)
    Added new and missing server info fields to IServerInfo:
    "serverEncryption", "proxyEncryption", "proxyAddress",
    "proxyRoot", "brokerAddress", "brokerEncryption",
    "brokerVersion", "peerAddress", "password".

Bugs fixed in 2012.1

#438221, 438596 (Job #50447, 54015)
    Fixed problem with 'p4 dirs' not returning error messages
    when the specified depot directories don't exist. Allow
    users to turn on/off tagged output per-command via the
    "inMap". Added handling of both "tagged" and "non-tagged"
    fields ("dir" and "dirName") returned from the Perforce.

#446371 (Job #55092, 55236)
    Fixed P4Java RPC network communication delay problem 'talking'
    to the Perforce server. Enabled socket 'TCP_NODELAY' (disabled
    Nagle's algorithm) by default. To turn off the 'TCP_NODELAY',
    set the "com.perforce.p4java.rpc.tcpNoDelay" or "tcpNoDelay"
    property to "false" when requesting an IOptionsServer from
    the ServerFactory class (as the Properties 'props' parameter
    pass to the getOptionsServer() method).

#464078 (Job #55266)
    Fixed issue with RPC socket connection pooling mechanism not
    being initialized in OneShotServerImpl.

#464056 (Job #56059)
    Fixed problem with IOptionsServer.execInputStringMapCmd method
    where the standard input ("inString" parameter) is being ignored
    in NtsServerImpl.

Major new functionality in 2011.2

#355465 (Job #46695)
    Added streams support for 'p4 diff2'; added the stream and
    parentStream options to GetFileDiffsOptions; corresponds to
    the "-S stream" and "-P parent" options in p4 diff2.

#365153 (Job #46694)
    Added streams support for 'p4 copy'; added the stream and
    parentStream options to CopyFilesOptions; corresponds to the
    "-S stream" and "-P parent" options in p4 copy.

#357762 (Job #46696)
    Added streams support for 'p4 dirs'; added the stream and
    parentStream options to GetDirectoriesOptions; corresponds
    to the "-S stream" and "-P parent" options in p4 dirs.

#365890 (Job #46697)
    Added streams support for 'p4 interchanges'; added the stream
    and parentStream options to GetInterchangesOptions; corresponds
    to the "-S stream" and "-P parent" options in p4 interchanges.

#365817 (Job #46698)
    Added streams support for 'p4 integrate'; added the stream
    and parentStream options to IntegrateFilesOptions; corresponds
    to the "-S stream" and "-P parent" options in p4 integrate.

#358488 (Job #43229)
    Implemented the 'p4 logtail' command as the getLogTail method
    on IOptionsServer. This method outputs the last block(s) of
    the errorLog and the offset required to get the next block
    when it becomes available.

#343002 (Job #47563)
    Implemented support for bypassing the writing of the ticket on
    the client machine's disk; instead, return it on the passed-in
    StringBuffer. Added dontWriteTicket option to LoginOptions;
    corresponds to '-p' option in p4 login.

#346153 (Job #46693)
    Implemented support for limiting output to the client workspaces
    dedicated to the stream. Added stream option to GetClientsOptions;
    corresponds to '-S' option in p4 clients.

#348126 (Job #46692)
    Implemented support for creating a new branch spec using a
    specified stream's internally generated mapping. Added stream
    and parentStream options to GetBranchSpecOptions; corresponds
    to '-S' and -P options in p4 branch.

#346149 (Job #46690)
    Implemented support for creating a new client spec dedicated
    to a stream; corresponds to '-S' option in p4 client. Updated
    IClientSummary to include stream support.

#350458 (Job #46687)
    Implemented the 'p4 istat' command as the
    getStreamIntegrationStatus method on IOptionsServer.
    This methods shows a stream's cached integration status
    with respect to its parent. If the cache is stale, either
    because newer changes have been submitted or the stream's
    branch view has changed, 'p4 istat' checks for pending
    integrations and updates the cache before showing status.

#343923 (Job #46686)
    Implemented the 'p4 streams' command as the getStreams method
    on IOptionsServer. This methods list of all streams currently
    known to the system. If a 'streamPath' is specified, the list
    of streams is limited to those matching the supplied path.

#344806 (Job #46685)
    Implemented the 'p4 stream' command as the createStream,
    deleteStream, getStream and updateStream methods on
    IOptionsServer. These methods are use to create, delete,
    retrieve and modify a stream specification. A stream
    specification ('spec') names a path in a stream depot to
    be treated as a stream. The spec also defines the stream's
    lineage, its view, and its expected flow of change.
    (See 'p4 help streamintro').

#339164 (Job #46668)
    Implemented the 'p4 diskspace' command as the getDiskSpace
    method on IOptionsServer. This method returns summary
    information about the current availability of disk space
    on the server.

#353798 (Job #46667)
    Implemented the 'p4 merge' command as the mergeFiles method
    on IClient. This method merges changes from one set of files
    (the 'source') into another (the 'target'). It is a simplified
    form of the 'p4 integrate' command.

#339188 (Job #44327)
    Implemented the 'p4 protect' command as the
    createProtectionEntries and updateProtectionEntries
    methods on IOptionsServer. These methods modify the
    protections table on the server and control Perforce
    permissions (users' access to files, commands, etc.).

#346423 (Job #41780, 41824)
    Implemented the 'p4 obliterate' command as the obliterateFiles
    method. This method removes files and their history from the
    depot permanently, precluding any possibility of recovery.

#327131 (Job #46113)
    Added branchResolves, deleteResolves and skipIntegratedRevs
    options to IntegrateFilesOptions; corresponds to '-R<flags>'
    options in p4 integrate.

#326034 (Job #46102)
    Added resolveFileBranching, resolveFileContentChanges,
    resolveFileDeletions, resolveMovedFiles and
    resolveFiletypeChanges options to ResolveFilesAutoOptions;
    corresponds to '-A<flags>' options in p4 resolve.

#380305 (Job #37798)
    Added support for filtering rules to allow the return of
    untranslated data (byte[]s instead of Strings) from the
    getExportRecords() method. Currently, the filtering rules
    are enabled for the 'p4 export' command.

Minor new functionality in 2011.2

#367652 (Job #46825)
    Added the caseInsensitiveNameFilter option to the
    GetClientsOptions, GetBranchSpecsOptions and GetLabelsOptions;
    corresponds to the '-E' option in p4 clients, branches and
    labels. This option allows case-insensitive name filtering
    for the above mentioned commands.

#370571 (Job #46826)
    Added new login method signature to support the "login [user]"
    command argument. This method allows the logged in superuser
    to request login for another user.

#343002 (Job #47563)
    Added the dontWriteTicket option to LoginOptions; corresponds
    to the '-p' option in p4 login. This allows the return of
    the auth ticket in the StringBuffer parameter of the login
    method, and not writing it to the ticket file on disk.

#374233 (Job #34333)
    Added the forceTextualMerge, ignoreWhitespaceChanges,
    ignoreWhitespace and ignoreLineEndings options to
    ResolveFilesAutoOptions; corresponds to the '-t -db -dw -dl'
    options in p4 resolve.

#358886 (Job #46233)
    Added support for constructing a FileSpec object with the
    result map from the "dirs" command output.

#374234 (Job #43124)
    Surfaced the lower-level map error/info/warning map processors
    in the IOptionsServer interface. See the IOptionsServer's
    getErrorStr, getErrorOrInfoStr and getInfoStr methods for
    usage details.

#337237 (Job #46682)
    Added the switchClientView method to IOptionsServer to
    support switching an existing client spec's view to a view
    defined in another client spec; corresponds to the '-s -t'
    options in p4 client.

#336310 (Job #46671)
    Added support for the shelvedChange field in IFileSpec.
    This new field will be captured from the result returned
    by the unshelveFiles and unshelveChangelist methods.

#326482 (Job #46114)
    Added support for a new 'operator' user type in IUserSummary.

#330020 (Job #46578)
    Added showTime option to GetLabelsOptions;
    corresponds to the '-t' option in p4 labels.

#330002 (Job #46577)
    Added showTime option to GetBranchSpecsOptions;
    corresponds to the '-t' option in p4 branches.

#330006 (Job #46572)
    Added showTime option to GetClientsOptions;
    corresponds to the '-t' option in p4 clients.

#329970 (Job #46091)
    Added safetyCheck option to SyncOptions;
    corresponds to the '-s' option in p4 sync.

#326140 (Job #46086)
    Added bypassClientDelete option to DeleteFilesOptions;
    corresponds to the '-k' option in p4 delete.

#326139 (Job #46063)
    Added maxFiles option to CopyFilesOptions;
    corresponds to the '-m' option in p4 copy.

#325939 (Job #46062)
    Added changelistId option to ResolveFilesAutoOptions;
    corresponds to the '-c' option in p4 resolve.

#342836 (Job #44623)
    Added the update(boolean force) method signature to IClient
    and the '-f' option to UpdateClientOptions. These changes
    allow the force update of locked clients.

#330955 (Job #46677)
    Added support for the new 'contentResolveType' field in
    IFileSpec for the 'resolve' command. Possible values are
    '3waytext', '3wayraw' and '2wayraw'.

Bugs fixed in 2011.2

#382664 (Job #49938)
    Fixed problem with content corruption when adding unicode files.

#378238 (Job #49985)
    Added checking for the "Password invalid" message and properly
    throw an AccessException instead of a generic RequestException.

#375505 (Job #46583)
    Added catching of unexpected "release2" and "flush2" protocol
    messages received by P4Java and throw a ProtocolError. This
    type of errors can happen when connecting through a proxy and
    the real server is down.

#368685 (Job #45050)
    Implemented the IChangelist update(force) method to allow
    force update of the 'Date' field in a submitted changelist.

#339171 (Job #42748)
    Inserted headers (file name	and revision) before each file
    content in the output from the IServer.getFileContents method
    when the "noHeaders" option is set to false (default) on
    GetFileContentsOptions. The result is also capped by the
    specified file revision. This is equivalent to the 'p4 print'
    command without the '-q' option.

#334658 (Job #47134)
    Added checking for the existing of the "isgroup" field key
    from the return map so that the ProtectionEntry is properly
    set to the group type.

#339091 (Job #46271)
    Corrected the map key from "type" to "changeType" so that the
    ChangelistSummary visibility field is properly set with the value
    from the result map on the IOptionsServer's getChangelists method.

#347539 (Job #44417, 44472)
    Implemented the 'p4 passwd' command with options '-O' and '-P'
    as the changePassword method on IOptionsServer to allow the user
    to change the password. This method allows the user to have a '#'
    in the password which is a limitation of updating the user's
    password using the user's form spec. However, the '-O' and '-P'
    options are not supported if your Perforce server is using
    security level 2 or 3.

#381075 (Job #42443)
    Updated the IChangelist.submit method to refresh files and jobs
    from the server before submitting. The user no longer needs to
    explicitly call the update() or refresh() method before submitting
    the changelist.

#397006 (Job #51466)
    Updated checking for symlinks on a Mac system with case-insensitive
    comparison of File.getAbsolutePath() and File.getCanonicalPath.

#396985 (Job #51617)
    Fixed the issue with the executable bit not set for file type
    unicode+x (xunicode).

Major new functionality in 2011.1

#289284 (Job #43532)
    Added the execInputStringMapCmd and execInputStreamStreamingMapCmd
    variants of the "raw" exec commands. These allow users to
    pass in form-like parameters as a string rather than a Map for
    those commands where this makes sense. These raw exec commands
    are not recommended for the typical developer or user, and have
    been supplied for low-level usage by third-party and internal
    tools developers.

#286577 (Job #43079)
    Implemented hash-based integrity checking for sync and related
    server-to-client file transfers as documented in the main 2010.2
    Perforce server documentation. This feature can be disabled
    for all clients on the server side as documented in the Perforce
    admin documentation, or in individual P4Java clients by setting
    the PropertyDefs.NON_CHECKED_SYNC property.

#285717 (Job #42288)
    Implemented the new p4d 2010.2 'p4 copy' command as the copyFile
    method on IClient. This method allows for integrate / resolve
    operations while ignoring past integration history.

#285717 (Job #43070)
    Implemented the new p4d 2010.2 'p4 configure' command as the
    showServerConfiguration and setServerConfigurationValue
    methods on IOptionsServer. This feature requires superuser
    permissions.

#285505 (Job #43186)
    Added a CoreFactory class to provide a small set of factory
    methods to create new local core objects with useful or common
    default values, and optionally also create them on the Perforce
    server. As a byproduct, most  core implementation classes now
    also contain factory methods.

#283676 (Job #41829)
    Implemented the new p4d 2010.2 server / protocol authentication
    scheme. This does not require users or developers to change
    anything from the 2010.1 release.

#281570 (Job #42788)
    Implemented a new low-level streaming interface that allows
    developers to get results one result at a time as they come
    in from the server (rather than en masse) using a callback.
    The results are handed to the callback method as a Java map,
    similar to the low-level execMapCmd (etc.) methods.

#272759 (Job #41636)
    Implemented the createDepot method for creating new depots
    in the repository.

    #273687 (Job #41552)
    Implemented file attributes on a per-file basis using
    the getExtendedFileSpecs method.

Minor new functionality in 2011.1

#289633 (Job #39472)
    Users of the IOptionsServer getMatchingLines method can
    now pass in an optional parameter to allow for the retrieval
    of info and warning messages from the Perforce server in
    response to things like lines being too long, etc.

#289590 (Job #43599)
    Added truncateDescriptions option to GetChangelistsOptions;
    corresponds to '-L' option in p4 changes.

#289541 (Job #43581)
    Added omitNonContributaryIntegrations option to the
    GetRevisionHistoryOptions class to implement '-s'
    functionality.

#289499 (Job #43611)
    Added support for getting additional Perforce user information
    with the IOptionsServer getUsers method using the equivalent
    of the '-l' option in GetUsersOptions.

#289452 (Job #43610)
    Added support for retrieving service users with the
    IOptionsServer getUsers method using GetUsersOptions; the
    new option corresponds to the '-a' flag on p4 users.

#288467 (Job #43076)
    Added support for the new Perforce user 'type' field.

#288444 (Job #43075)
    Added support for the new PasswordTimeout field in Perforce
    user groups (IUserGroup).

#288276 (Job #43073)
    Added support for the new 'type' field in changelists; see
    the documentation for IChangelistSummary for details. Also
    added related -f option to the IOptionsServer getChangelists
    method.

#288206 (Job #43072)
    Added support for the annotate '-I' option in IOptionsServer.

#286845 (Job #43157)
    Added several methods to RequestException and FileSpec to
    support more extensive error code retrieval for server-
    generated errors. Use of the added methods is currently
    considered to be experimental, unsupported, and undocumented,
    but developers who know what they're doing and need this sort
    of low-level error subcode access are welcome to try it....

#285505 (Job #35253)
    Made it possible to (optionally) issue arbitrary commands
    through the execMapCmd method with function name checking
    turned off. This feature is potentially dangerous and should
    not be used unless you a) need lower-level command support;
    and b) can cope with the consequences, which may include
    client- or server-side data corruption.

#284362 (Job #43123)
    Added getManifest method to com.perforce.p4java.Manifest
    to allow users to retrieve the associated jar file
    manifest (if it exists); changed Manifest's getP4JVersionString
    and getP4JDateString methods to use the jar manifest version
    and date attributes if they exist.

#283970 (Job #42964)
    Class com.perforce.p4java.Metadata now has a static main
    entry point that can be used to print out version and other
    metadata from the enclosing jar file's manifest from the
    command line or other execution environment.

Major new functionality in 2010.1

#262626 (Job #39410)
    Implemented a new global usage options class and feature for P4Java.
    This feature allows users to set a limited number of options
    (typically corresponding to options detailed in "p4 help usage"
    documentation, but not limited to that) that can apply to all
    commands issued by a server. See the Javadoc commentary for
    class com.perforce.p4java.options.UsageOptions for details.

#261838 (Job #39408)
    Implemented a new Options-class based set of methods and interfaces
    to allow for forwards and backwards binary compatibility. See the
    Javadoc comments for class com.perforce.p4java.options.Options
    and associated documentation for details. This change should have
    no impact on current users unless they wish to adopt the new
    options-class-based features.

Minor new functionality in 2010.1

#265749 (Job #40849)
    Added undoc max files (-m) option to IServer.getDepotFiles's
    GetDepotFilesOptions. Note that this is an undoc option and
    will cause a RequestException if used with servers that do not
    support the new -m option.

#262626 (Job #40738)
    Implemented p4 grep functionality as IOptionsServer's
    getMatchingLines method.

#252734 (Job #39466)
    Implemented IServer.getLoginStatus, corresponding to login -s, to
    allow users to determine their Perforce login status.

#263740 (Job #040670)
    P4Java jar file is now digitally signed.  Certificate information
    can be verified by using the jarsigner utility.

Bugs fixed in 2010.1

#266827 (Job #40877)
    Jobs marked as fixed using server.fixJobs() or an external fix
    operation now show up properly if an associated changelist is
    submitted from P4Java. Previously the job fix records were
    missing after submission.

#265493 (Job #40829)
    Sync operations on IClient objects that are not the current client
    of the active server object now cause a suitable RequestException
    to be thrown. Previous behavior was to silently sync whichever
    client was currently attached to the server (if any).

#263341 (Job #38602)
    Copyright symbols in text file no longer cause automatic file type
    detection to set the file type to binary. Note that P4Java file type
    inference is always probabilistic, and may cause problems with
    certain non-ASCII character sets, and -- in general -- users should
    always use type maps or explicit type specifiers where there's any
    chance of ambiguity.

#263794 (Job #39015)
    P4Java streams-based commands (principally file diff and file
    content retrieval methods) now correctly throw exceptions when
    the server denies access due to login session expiry, etc. This
    is also now true for any server-detected error.
    Previous versions simply returned null streams regardless of
    the error.

#263551 (Job #39525)
    Checking out a file that doesn't exist in the client workspace now
    gives a useful status message. Previous versions were silent when
    they detected the missing file.

#263826 (Job #40205)
    Syncing to rev #0, fspec.getAction() on successfully-deleted filespecs
    now returns "deleted" instead of null.

#264092 (Job #40346)
    Base file name and revision is now available from IClient.integrateFiles
    output when IntegrationOptions.setDisplayBaseDetails(true) is
    used.

#263522 (Job #40601)
    IClient.resolveFile now correctly resolves binary files. Previous
    implementation ignored attempts to resolve binary files.

#259993 (Job #39437)
    IMapEntry.getRight(true) now returns correctly quoted right side
    entry string.

Major new functionality in 2009.3

#234216 (Job #37582)
    The undoc interchanges command has been implemented in P4Java.

#231905 (Job #37568)
    Diff2 command implemented in P4Java.

#231806 (Job #37558)
    Job deletion now available through P4Java.

#220561 (Job #32576)
    Implemented zeroconf-based browsing in P4Java based on JmDNS.
    Note that JmDNS is not bundled with P4Java -- it just has to be
    on the classpath somewhere for zeroconf to work; if it's not there,
    you just can't do zeroconf browsing.

Minor new functionality in 2009.3

#245412 (Job #38974)
    Added a new System property, PropertyDefs.WRITE_IN_PLACE_KEY, that
    if set to "true", will allow sync file writes to be performed in
    place rather than to a temporary file (which is then renamed). The
    motivation here is that on Windows systems, the JVM does not do
    atomic renames properly (see Sun's bug ID 4017593 for a discussion
    of this), which can have a performance impact with forced syncs
    when a file already exists. Do not use this feature unless you
    have been advised to by Perforce support personnel, and / or you
    are fully aware of the consequences of doing this, which include
    possible partial reads of the target file(s) during the sync or
    improper file contents after network problems. Both cases are
    highly unlikely, and in any case no data corruption will occur.

#238378 (Job #38059)
    IServerInfo now has a method that returns the Proxy Server version
    if a proxy is being used.

#234798 (Job #37750)
    Added IServer.isCaseSensitive method to test if a Perforce server
    is case sensitive or not. This should return true on Linux servers
    and false on Windows servers.

#248702 (Job #039041)
    Support reusing sockets for multiple commands run against an
    IServer object. com.perforce.p4java.rpc.socketPoolSize can now be
    configured as a property specified to the ServerFactory class when
    requesting a server that will control how many sockets are retained
    when a command completes to be used by subsequent commands.  This
    option is off by default and a value of greater than zero must be
    set to turn on socket pooling.  A system property,
    com.perforce.p4java.RPC_SOCKET_IDLE_TIME, now controls how much
    time a socket can be idle for before it is closed by the client.

Bugs fixed in 2009.3

#262259 (Job #40201)
    Tightened up file / stream / socket close logic and error
    reporting as a side effect of fixing bug #40241. This should
    help Perforce support debug left-open system file descriptor
    issues and reduce P4Java resource usage.

#261907 (Job #40241)
    In certain cases of binary file transfers during sync operations,
    file CRC values were incorrectly logged as "bad". The file
    contents were correctly transferred, but sockets and / or
        file handles were being left open in P4Java as a side-effect.

#253486 (Job #039486)
    Submit failure was not handled properly; in some situation, it
    was possible to submit files despite submit	failure.

#253486 (Job #039304)
    Users erroneously saw a "A revision specification (# or @) cannot
    be used here." message when using IServer.getProtectionEntries().

#248698 (Job #039012)
    IFileAnnotation.getLine(boolean processLineEndings) no longer
    returns incorrect line endings when running annotate against a
    Windows server.  Previously when true was specified as the first
    parameter to a Windows server the String returned would contain
    an extra '\r' character.

Major new functionality in 2009.2

#216495 (Job #35310)
    P4Java type and method names refactored to conform to the following
    general rules:

    * "P4J" prefix deleted;
    * Use "I" as interface name prefix;
    * "Impl" suffix for impl classes deleted;
    * Regularize "ChangeList" to "Changelist";
    * Deleted "List" and "Summary" suffixes for methods, eg.
      getClientSummaryList -> getClients;
    * Normalized "new" prefix to "create" prefix, e.g.
      newClient -> createClient.

#214537 (Job #35428)
    P4Java public interface definitions now include setter methods
    as well as getters for all public fields.

#216787 (Job #35545)
    P4Java filespec-related interfaces have been refactored to simplify
    access and functional relationships.

#216659 (Job #35550)
    IServerResource-based resource (clients, jobs, changelists,
    labels, and branches) interfaces and associated functionality
    have been refactored to syntactically and semantically distinguish
    between "summary" and "full" versions of the associated objects.

#216095 (Job #35674)
    View-based objects (clients, labels, branches, etc.) now use a
    unified view map class (ViewMap) as the basis for all view map
    functionality.

#216679 (Job #32564)
    P4Java now supports the full creation / deletion / updating
    of Perforce users through the IServer interface.

#216828 (Job #35810)
    P4Java now supports the full creation / deletion / updating
    of Perforce user groups through the IServer interface.

#211525 (Job #34925)
    P4Java now supports the annotate command for files under
    its control.

#216488 (Job #35239)
    P4Java now supports the "protects" command.

#216531 (Job #35797)
    P4Java now supports counter create / set / delete operations.

#216555 (Job #35801)
    P4Java now supports the reviews command.

#211334 (Job #35000)
    P4Java now supports the dbschema and export commands (with
    documented limitations).

Minor new functionality in 2009.2

#216412 (Job #35081)
    P4Java now supports the "-k" option to the move and edit
    commands.

#216463 (Job #35444)
    P4Java now supports the -a option to login.

#216876 (Job #34567)
    IServer.deletePendingChangelist now returns a status string on
    completion.

#216871 (Job #34596)
    IServer.deleteClient now returns a status string on completion.

Bugs fixed in 2009.2

#240240 (Job #38402)
    P4Java now reports the have revision correct under all
    circumstances when using the file spec operations. Previous
    releases occasionally showed the have revision as either higher
    or lower than the actual have revision.

#240240 (Job #38015)
    P4Java now correctly releases file handles on sync and other
    file operations with binary files. As a side effect, P4Java
    should no longer log "Bad PKZIP trailer length" messages
    on syncs and other file operations. Note that even when the
    file handles were not released or the bad PKZIP trailer
    messages appeared, data was being correctly transferred
    and file contents were not being affected.

#240240 (Job #38231)
    Added IProtectionEntry excluded path methods to detect and / or
    set excluded paths for protection entries.

#240240 (Job #37980)
    IServer.getProtectionEntries now returns correct data when
    used with a file specification parameter.

#238859 (Job #37970)
    P4Java now works correctly with proxied servers when local
    proxy caches are out of date.

#238858 (Job #37980)
    P4Java now returns correct protection entries when used with
    file specification arguments.

#232364 (Job #37598)
    P4Java now sets a file's head modification time correctly on
    submits; this value is now available properly when using the
    getExtendedFileSpecs method on the IServer interface.

#231471 (Job #37521)
    P4Java now does a better job of detecting known binary file types
    and Unicode files on both Unicode and non-Unicode servers.
    Please note, however, that customers are always strongly
    encouraged to use explicit type maps for all file types,
    as file type inference in the absence of type maps or
    -t flags (etc.) is heuristic and is not guaranteed to
    get the "correct" answer in all circumstances.

#228643 (Job #36781)
    P4Java's Metadata class methods getP4JVersionString() and
    getP4JDateString() now return P4Java release version and date
    metadata useful for debugging (note that the 2009.2 Metadata
    class was known as the P4Java class in previous releases).

#228609 (Job #37128)
    P4Java can now communicate properly with the Perforce server
    when used with the tr_TR locale.

#226748 (Job #36923)
    Fixed bug where merge operations sometimes resulted in a
    ConnectionException with the message "No metadata defined for
    RPC function encoding: client-OpenMerge2". As a side effect,
    two-way merges are now implemented in P4Java, allowing for
    (safe) merges on binary files.

#225502 (Job #36870)
    P4Java now properly handles submits of files that don't exist
    on the local client; the error message no longer mentions the
    "lbr-ForsakeFile" function.

#219483 (Job #36074)
    Clients with no Host field updated through P4Java no longer
    have the Host field set to 'null' after the update.

#217317 (Job #35376)
    P4Java authentication ticket system now checks properties for
    relevant property definitions when saving a ticket value.

#217319 (Job #35378)
    Tickets files used by P4Java are no longer set read-only with JDK5
    and / or Windows systems.

#217322 (Job #35850)
    When marking a JAR file for add, P4Java correctly detects the type
    as binary (this is true now for PKZIP-derived files in general).

#216522 (Job #35104)
    IServer.execMapCmd(CmdSpec.INFO.name(), ... ) correctly down-cases
    the command name with the RPC implementation.

#216289 (Job #35240)
    P4Java correctly manages an empty authentication tickets file on
    Windows platforms.

#216261 (Job #35252)
    P4Java now uses an 'unset' value for client names rather than
    defaulting to local host names when no client is set.

#216315 (Job #35290)
    P4Java now correctly parses and respects the IFileSpec endRevision
    field value with file history commands.