#include "Version.h"

#include <QStringList>
#include <QUrl>
#include <QRegularExpression>
#include <QRegularExpressionMatch>

Version::Version(const QString &str) : m_string(str)
{
	parse();
}

bool Version::operator<(const Version &other) const
{
	const int size = qMax(m_sections.size(), other.m_sections.size());
	for (int i = 0; i < size; ++i)
	{
		const Section sec1 = (i >= m_sections.size()) ? Section("0") : m_sections.at(i);
		const Section sec2 =
			(i >= other.m_sections.size()) ? Section("0") : other.m_sections.at(i);
		if (sec1 != sec2)
		{
			return sec1 < sec2;
		}
	}

	return false;
}
bool Version::operator<=(const Version &other) const
{
	return *this < other || *this == other;
}
bool Version::operator>(const Version &other) const
{
	const int size = qMax(m_sections.size(), other.m_sections.size());
	for (int i = 0; i < size; ++i)
	{
		const Section sec1 = (i >= m_sections.size()) ? Section("0") : m_sections.at(i);
		const Section sec2 =
			(i >= other.m_sections.size()) ? Section("0") : other.m_sections.at(i);
		if (sec1 != sec2)
		{
			return sec1 > sec2;
		}
	}

	return false;
}
bool Version::operator>=(const Version &other) const
{
	return *this > other || *this == other;
}
bool Version::operator==(const Version &other) const
{
	const int size = qMax(m_sections.size(), other.m_sections.size());
	for (int i = 0; i < size; ++i)
	{
		const Section sec1 = (i >= m_sections.size()) ? Section("0") : m_sections.at(i);
		const Section sec2 =
			(i >= other.m_sections.size()) ? Section("0") : other.m_sections.at(i);
		if (sec1 != sec2)
		{
			return false;
		}
	}

	return true;
}
bool Version::operator!=(const Version &other) const
{
	return !operator==(other);
}

void Version::parse()
{
	m_sections.clear();

	// FIXME: this is bad. versions can contain a lot more separators...
	QStringList parts = m_string.split('.');

	for (const auto part : parts)
	{
		m_sections.append(Section(part));
	}
}