Package org.apache.http
Class ProtocolVersion
- java.lang.Object
 - 
- org.apache.http.ProtocolVersion
 
 
- 
- All Implemented Interfaces:
 java.io.Serializable,java.lang.Cloneable
- Direct Known Subclasses:
 HttpVersion
@Contract(threading=IMMUTABLE) public class ProtocolVersion extends java.lang.Object implements java.io.Serializable, java.lang.Cloneable
Represents a protocol version. The "major.minor" numbering scheme is used to indicate versions of the protocol.This class defines a protocol version as a combination of protocol name, major version number, and minor version number. Note that
equals(java.lang.Object)andhashCode()are defined as final here, they cannot be overridden in derived classes.- Since:
 - 4.0
 - See Also:
 - Serialized Form
 
 
- 
- 
Constructor Summary
Constructors Constructor Description ProtocolVersion(java.lang.String protocol, int major, int minor)Create a protocol version designator. 
- 
Method Summary
All Methods Instance Methods Concrete Methods Modifier and Type Method Description java.lang.Objectclone()intcompareToVersion(ProtocolVersion that)Compares this protocol version with another one.booleanequals(java.lang.Object obj)Checks equality of this protocol version with an object.ProtocolVersionforVersion(int major, int minor)Obtains a specific version of this protocol.intgetMajor()Returns the major version number of the protocol.intgetMinor()Returns the minor version number of the HTTP protocol.java.lang.StringgetProtocol()Returns the name of the protocol.booleangreaterEquals(ProtocolVersion version)Tests if this protocol version is greater or equal to the given one.inthashCode()Obtains a hash code consistent withequals(java.lang.Object).booleanisComparable(ProtocolVersion that)Checks whether this protocol can be compared to another one.booleanlessEquals(ProtocolVersion version)Tests if this protocol version is less or equal to the given one.java.lang.StringtoString()Converts this protocol version to a string. 
 - 
 
- 
- 
Constructor Detail
- 
ProtocolVersion
public ProtocolVersion(java.lang.String protocol, int major, int minor)Create a protocol version designator.- Parameters:
 protocol- the name of the protocol, for example "HTTP"major- the major version number of the protocolminor- the minor version number of the protocol
 
 - 
 
- 
Method Detail
- 
getProtocol
public final java.lang.String getProtocol()
Returns the name of the protocol.- Returns:
 - the protocol name
 
 
- 
getMajor
public final int getMajor()
Returns the major version number of the protocol.- Returns:
 - the major version number.
 
 
- 
getMinor
public final int getMinor()
Returns the minor version number of the HTTP protocol.- Returns:
 - the minor version number.
 
 
- 
forVersion
public ProtocolVersion forVersion(int major, int minor)
Obtains a specific version of this protocol. This can be used by derived classes to instantiate themselves instead of the base class, and to define constants for commonly used versions.The default implementation in this class returns
thisif the version matches, and creates a newProtocolVersionotherwise.- Parameters:
 major- the major versionminor- the minor version- Returns:
 - a protocol version with the same protocol name and the argument version
 
 
- 
hashCode
public final int hashCode()
Obtains a hash code consistent withequals(java.lang.Object).- Overrides:
 hashCodein classjava.lang.Object- Returns:
 - the hashcode of this protocol version
 
 
- 
equals
public final boolean equals(java.lang.Object obj)
Checks equality of this protocol version with an object. The object is equal if it is a protocl version with the same protocol name, major version number, and minor version number. The specific class of the object is not relevant, instances of derived classes with identical attributes are equal to instances of the base class and vice versa.- Overrides:
 equalsin classjava.lang.Object- Parameters:
 obj- the object to compare with- Returns:
 trueif the argument is the same protocol version,falseotherwise
 
- 
isComparable
public boolean isComparable(ProtocolVersion that)
Checks whether this protocol can be compared to another one. Only protocol versions with the same protocol name can becompared.- Parameters:
 that- the protocol version to consider- Returns:
 trueifcompareToVersioncan be called with the argument,falseotherwise
 
- 
compareToVersion
public int compareToVersion(ProtocolVersion that)
Compares this protocol version with another one. Only protocol versions with the same protocol name can be compared. This method does not define a total ordering, as it would be required forComparable.- Parameters:
 that- the protocol version to compare with- Returns:
 - a negative integer, zero, or a positive integer as this version is less than, equal to, or greater than the argument version.
 - Throws:
 java.lang.IllegalArgumentException- if the argument has a different protocol name than this object, or if the argument isnull
 
- 
greaterEquals
public final boolean greaterEquals(ProtocolVersion version)
Tests if this protocol version is greater or equal to the given one.- Parameters:
 version- the version against which to check this version- Returns:
 trueif this protocol version iscomparableto the argument andcomparesas greater or equal,falseotherwise
 
- 
lessEquals
public final boolean lessEquals(ProtocolVersion version)
Tests if this protocol version is less or equal to the given one.- Parameters:
 version- the version against which to check this version- Returns:
 trueif this protocol version iscomparableto the argument andcomparesas less or equal,falseotherwise
 
- 
toString
public java.lang.String toString()
Converts this protocol version to a string.- Overrides:
 toStringin classjava.lang.Object- Returns:
 - a protocol version string, like "HTTP/1.1"
 
 
- 
clone
public java.lang.Object clone() throws java.lang.CloneNotSupportedException- Throws:
 java.lang.CloneNotSupportedException
 
 - 
 
 -