QmlJS: Add ComponentVersion class to simplify dealing with versions.

This commit is contained in:
Christian Kamm
2010-05-20 15:41:30 +02:00
parent 0d5d6344bd
commit ea5ca79900
5 changed files with 93 additions and 9 deletions

View File

@@ -20,7 +20,8 @@ HEADERS += \
$$PWD/qmljscheck.h \ $$PWD/qmljscheck.h \
$$PWD/qmljsscopebuilder.h \ $$PWD/qmljsscopebuilder.h \
$$PWD/qmljslineinfo.h \ $$PWD/qmljslineinfo.h \
$$PWD/qmljscompletioncontextfinder.h $$PWD/qmljscompletioncontextfinder.h \
$$PWD/qmljscomponentversion.h
SOURCES += \ SOURCES += \
$$PWD/qmljsbind.cpp \ $$PWD/qmljsbind.cpp \
@@ -32,7 +33,8 @@ SOURCES += \
$$PWD/qmljscheck.cpp \ $$PWD/qmljscheck.cpp \
$$PWD/qmljsscopebuilder.cpp \ $$PWD/qmljsscopebuilder.cpp \
$$PWD/qmljslineinfo.cpp \ $$PWD/qmljslineinfo.cpp \
$$PWD/qmljscompletioncontextfinder.cpp $$PWD/qmljscompletioncontextfinder.cpp \
$$PWD/qmljscomponentversion.cpp
OTHER_FILES += \ OTHER_FILES += \
$$PWD/parser/qmljs.g $$PWD/parser/qmljs.g

View File

@@ -187,15 +187,12 @@ bool Bind::visit(UiImport *ast)
{ {
ImportInfo info; ImportInfo info;
info.majorVersion = QmlObjectValue::NoVersion;
info.minorVersion = QmlObjectValue::NoVersion;
if (ast->versionToken.isValid()) { if (ast->versionToken.isValid()) {
const QString versionString = _doc->source().mid(ast->versionToken.offset, ast->versionToken.length); const QString versionString = _doc->source().mid(ast->versionToken.offset, ast->versionToken.length);
const int dotIdx = versionString.indexOf(QLatin1Char('.')); const int dotIdx = versionString.indexOf(QLatin1Char('.'));
if (dotIdx != -1) { if (dotIdx != -1) {
info.majorVersion = versionString.left(dotIdx).toInt(); info.version = ComponentVersion(versionString.left(dotIdx).toInt(),
info.minorVersion = versionString.mid(dotIdx + 1).toInt(); versionString.mid(dotIdx + 1).toInt());
} }
} }

View File

@@ -32,6 +32,7 @@
#include <qmljs/parser/qmljsastvisitor_p.h> #include <qmljs/parser/qmljsastvisitor_p.h>
#include <qmljs/qmljsinterpreter.h> #include <qmljs/qmljsinterpreter.h>
#include <qmljs/qmljscomponentversion.h>
#include <QtCore/QHash> #include <QtCore/QHash>
#include <QtCore/QStringList> #include <QtCore/QStringList>
@@ -52,8 +53,7 @@ public:
struct ImportInfo { struct ImportInfo {
QString name; QString name;
int majorVersion; ComponentVersion version;
int minorVersion;
}; };
QList<ImportInfo> fileImports() const; QList<ImportInfo> fileImports() const;

View File

@@ -0,0 +1,50 @@
#include "qmljscomponentversion.h"
using namespace QmlJS;
const int ComponentVersion::NoVersion = -1;
ComponentVersion::ComponentVersion()
: _major(NoVersion), _minor(NoVersion)
{
}
ComponentVersion::ComponentVersion(int major, int minor)
: _major(major), _minor(minor)
{
}
ComponentVersion::~ComponentVersion()
{
}
bool ComponentVersion::isValid() const
{
return _major >= 0 && _minor >= 0;
}
namespace QmlJS {
bool operator<(const ComponentVersion &lhs, const ComponentVersion &rhs)
{
return lhs.major() < rhs.major()
|| (lhs.major() == rhs.major() && lhs.minor() < rhs.minor());
}
bool operator<=(const ComponentVersion &lhs, const ComponentVersion &rhs)
{
return lhs.major() < rhs.major()
|| (lhs.major() == rhs.major() && lhs.minor() <= rhs.minor());
}
bool operator==(const ComponentVersion &lhs, const ComponentVersion &rhs)
{
return lhs.major() == rhs.major() && lhs.minor() == rhs.minor();
}
bool operator!=(const ComponentVersion &lhs, const ComponentVersion &rhs)
{
return !(lhs == rhs);
}
}

View File

@@ -0,0 +1,35 @@
#ifndef QMLJSCOMPONENTVERSION_H
#define QMLJSCOMPONENTVERSION_H
#include "qmljs_global.h"
namespace QmlJS {
class QMLJS_EXPORT ComponentVersion
{
int _major;
int _minor;
public:
static const int NoVersion;
ComponentVersion();
ComponentVersion(int major, int minor);
~ComponentVersion();
int major() const
{ return _major; }
int minor() const
{ return _minor; }
bool isValid() const;
};
bool operator<(const ComponentVersion &lhs, const ComponentVersion &rhs);
bool operator<=(const ComponentVersion &lhs, const ComponentVersion &rhs);
bool operator==(const ComponentVersion &lhs, const ComponentVersion &rhs);
bool operator!=(const ComponentVersion &lhs, const ComponentVersion &rhs);
} // namespace QmlJS
#endif // QMLJSCOMPONENTVERSION_H