Represents the version number of an assembly, operating system, or the xtd. This class cannot be inherited.
major.minor[.build[.revision]]
Public Constructors | |
version () noexcept=default | |
Initializes a new instance of the xtd::version class. | |
version (const xtd::string &version) | |
Initializes a new instance of the xtd::version class using the specified string. | |
version (int32 major, int32 minor) | |
Initializes a new instance of the xtd::version class using the specified major and minor values. | |
version (int32 major, int32 minor, int32 build) | |
Initializes a new instance of the xtd::version class using the specified major, minor and build values. | |
version (int32 major, int32 minor, int32 build, int32 revision) | |
Initializes a new instance of the xtd::version class using the specified major, minor, build and revision values. | |
Public Properties | |
int32 | build () const noexcept |
Gets the value of the build component of the version number for the current xtd::version object. | |
int32 | major () const noexcept |
Gets the value of the major component of the version number for the current xtd::version object. | |
int16 | major_revision () const noexcept |
Gets the high 16 bits of the revision number. | |
int32 | minor () const noexcept |
Gets the value of the minor component of the version number for the current xtd::version object. | |
int16 | minor_revision () const noexcept |
Gets the low 16 bits of the revision number. | |
int32 | revision () const noexcept |
Gets the value of the revision component of the version number for the current xtd::version object. | |
Public Methods | |
int32 | compare_to (const version &version) const noexcept override |
Compares the current xtd::version object to a specified object and returns an indication of their relative values. | |
bool | equals (const version &v) const noexcept override |
Indicates whether the current object is equal to another object of the same type. | |
xtd::string | to_string () const noexcept override |
Converts the value of the current xtd::version object to its equivalent xtd::string representation. | |
xtd::string | to_string (size_t field_count) const |
Converts the value of the current xtd::version object to its equivalent xtd::string representation. A specified count indicates the number of components to return. | |
virtual bool | equals (const object &obj) const noexcept |
Determines whether the specified object is equal to the current object. | |
template<typename object_a_t , typename object_b_t > | |
static bool | equals (const object_a_t &object_a, const object_b_t &object_b) noexcept |
Determines whether the specified object instances are considered equal. | |
Public Static Methods | |
static version | parse (const xtd::string &input) |
Converts the string representation of a version number to an equivalent Version object. | |
static bool | try_parse (const xtd::string &input, version &result) noexcept |
Tries to convert the string representation of a version number to an equivalent xtd::version object, and returns a value that indicates whether the conversion succeeded. | |
Additional Inherited Members | |
Public Member Functions inherited from xtd::object | |
object ()=default | |
Create a new instance of the ultimate base class object. | |
virtual size_t | get_hash_code () const noexcept |
Serves as a hash function for a particular type. | |
virtual type_object | get_type () const noexcept |
Gets the type of the current instance. | |
template<typename object_t > | |
xtd::uptr< object_t > | memberwise_clone () const |
Creates a shallow copy of the current object. | |
Public Member Functions inherited from xtd::icomparable< version > | |
Public Member Functions inherited from xtd::iequatable< version > | |
Static Public Member Functions inherited from xtd::object | |
template<typename object_a_t , typename object_b_t > | |
static bool | equals (const object_a_t &object_a, const object_b_t &object_b) noexcept |
Determines whether the specified object instances are considered equal. | |
template<typename object_a_t , typename object_b_t > | |
static bool | reference_equals (const object_a_t &object_a, const object_b_t &object_b) noexcept |
Determines whether the specified object instances are the same instance. | |
|
defaultnoexcept |
Initializes a new instance of the xtd::version class.
Property | Value |
---|---|
xtd::version::major | 0 |
xtd::version::minor | 0 |
xtd::version::build | -1 |
xtd::version::revision | -1 |
|
explicit |
Initializes a new instance of the xtd::version class using the specified string.
version | A string containing the major, minor, build, and revision numbers, where each number is delimited with a period character ('.'). |
xtd::argument_exception | version has fewer than two components or more than four components. |
xtd::argument_out_of_range_exception | A major, minor, build, or revision component is less than zero. |
xtd::format_exception | At least one component of version does not parse to an integer. |
xtd::overflow_exception | At least one component of version represents a number greater than std::numeric_limits<int32>::max(). |
major.minor[.build[.revision]]
Initializes a new instance of the xtd::version class using the specified major and minor values.
major | The major version number. |
minor | The minor version number. |
xtd::out_of_range_exception | major or minor is less than zero. |
Property | Value |
---|---|
xtd::version::major | major |
xtd::version::minor | minor |
xtd::version::build | undefined (-1) |
xtd::version::revision | undefined (-1) |
Initializes a new instance of the xtd::version class using the specified major, minor and build values.
major | The major version number. |
minor | The minor version number. |
build | The build version number. |
xtd::out_of_range_exception | major, minor or build is less than zero. |
Property | Value |
---|---|
xtd::version::major | major |
xtd::version::minor | minor |
xtd::version::build | build |
xtd::version::revision | undefined (-1) |
Initializes a new instance of the xtd::version class using the specified major, minor, build and revision values.
major | The major version number. |
minor | The minor version number. |
build | The build version number. |
revision | The revision version number. |
xtd::out_of_range_exception | major, minor, build or revision is less than zero. |
Property | Value |
---|---|
xtd::version::major | major |
xtd::version::minor | minor |
xtd::version::build | build |
xtd::version::revision | revision |
|
noexcept |
Gets the value of the build component of the version number for the current xtd::version object.
|
noexcept |
Gets the value of the major component of the version number for the current xtd::version object.
|
noexcept |
Gets the high 16 bits of the revision number.
|
noexcept |
Gets the value of the minor component of the version number for the current xtd::version object.
|
noexcept |
Gets the low 16 bits of the revision number.
|
noexcept |
Gets the value of the revision component of the version number for the current xtd::version object.
Compares the current xtd::version object to a specified object and returns an indication of their relative values.
version | An object to compare. |
Return value | Meaning |
---|---|
Less than zero | The current xtd::version object is a version before version. |
Zero | The current xtd::version object is the same version as version. |
Greater than zero | The current xtd::version object is a version subsequent to version. |
Implements xtd::icomparable< version >.
|
overridevirtualnoexcept |
Indicates whether the current object is equal to another object of the same type.
obj | An object to compare with this object. |
true
if the current object is equal to the other parameter; otherwise, false
. Implements xtd::iequatable< version >.
|
overridevirtualnoexcept |
Converts the value of the current xtd::version object to its equivalent xtd::string representation.
major.minor[.build[.revision]]For example, if you create a xtd::version object using the constructor xtd::version(1, 1), the returned string is "1.1". If you create a xtd::version object using the constructor xtd::version(1, 3, 4, 2), the returned string is "1.3.4.2".
Reimplemented from xtd::object.
xtd::string xtd::version::to_string | ( | size_t | field_count | ) | const |
Converts the value of the current xtd::version object to its equivalent xtd::string representation. A specified count indicates the number of components to return.
field_count | The number of components to return. The field_count ranges from 0 to 4. |
field_count | Return Value |
---|---|
0 | An empty string (""). |
1 | major |
2 | major.minor |
3 | major.minor.build |
4 | major.minor.build.revision |
xtd::argument_exception | field_count is more than 4 -or- field_count is more than the number of components defined in the current xtd::version object. |
|
static |
Converts the string representation of a version number to an equivalent Version object.
input | A string that contains a version number to convert. |
xtd::argument_out_of_range_exception | A major, minor, build, or revision component is less than zero. |
xtd::format_exception | At least one component of input does not parse to an integer. |
xtd::overflow_exception | At least one component of input represents a number greater than std::numeric_limits<int32>::max(). |
major.minor[.build[.revision]]
|
staticnoexcept |
Tries to convert the string representation of a version number to an equivalent xtd::version object, and returns a value that indicates whether the conversion succeeded.
input | A string that contains a version number to convert. |
result | When this method returns, contains the xtd::version equivalent of the number that is contained in input, if the conversion succeeded. If input is empty, or if the conversion fails, result is empty when the method returns. |
major.minor[.build[.revision]]where major, minor, build, and revision are the string representations of the version number's four components: major version number, minor version number, build number, and revision number, respectively. Optional components are shown in square brackets ([ and ]). The components must appear in order and must be separated by periods.
|
virtualnoexcept |
Determines whether the specified object is equal to the current object.
obj | The object to compare with the current object. |
Reimplemented from xtd::object.
|
inlinestaticnoexcept |
Determines whether the specified object instances are considered equal.
object_a | The first object to compare. |
object_b | The second object to compare. |