summaryrefslogtreecommitdiffstats
path: root/MultiMCVersion.h
blob: 8978516ba2a31d88019f4c8862a470a9b445cd9e (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
/* Copyright 2013 MultiMC Contributors
 *
 * Licensed under the Apache License, Version 2.0 (the "License");
 * you may not use this file except in compliance with the License.
 * You may obtain a copy of the License at
 * 
 *     http://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 */

#pragma once

#include <QString>

/*!
 * \brief The Version class represents a MultiMC version number.
 */
struct MultiMCVersion
{
	/*!
	 * \brief Converts the Version to a string.
	 * \return The version number in string format (major.minor.revision.build).
	 */
	QString toString() const
	{
		QString vstr = QString("%1.%2").arg(
				QString::number(major),
				QString::number(minor));

		if (build >= 0) vstr += "." + QString::number(build);
		if (!channel.isEmpty()) vstr += "-" + channel;
		if (!buildType.isEmpty()) vstr += "-" + buildType;

		return vstr;
	}

	/*!
	 * \brief The major version number.
	 * This is no longer going to always be 5 for MultiMC 5. Doing so is useless.
	 * Instead, we'll be starting major off at 1 and incrementing it with every major feature.
	 */
	int major;
	
	/*!
	 * \brief The minor version number.
	 * This number is incremented for major features and bug fixes.
	 */
	int minor;
	
	/*!
	 * \brief The build number.
	 * This number is automatically set by Buildbot it is set to the build number of the buildbot 
	 * build that this build came from.
	 * If this build didn't come from buildbot and no build number was given to CMake, this will default
	 * to -1, causing it to not show in this version's string representation.
	 */
	int build;

	/*!
	 * \brief This build's channel.
	 */
	QString channel;

	/*!
	 * \brief The build type.
	 * This indicates the type of build that this is. For example, lin64 or custombuild.
	 */
	QString buildType;
};