mirror of
https://github.com/MultiMC/MultiMC5.git
synced 2024-11-20 17:11:57 +00:00
03b13b0b3f
Fix #396
171 lines
3.8 KiB
C++
171 lines
3.8 KiB
C++
#pragma once
|
|
#include <QString>
|
|
#include <QPair>
|
|
#include <QList>
|
|
#include <QStringList>
|
|
#include <QMap>
|
|
#include <QDir>
|
|
#include <memory>
|
|
|
|
#include "logic/minecraft/OneSixRule.h"
|
|
#include "logic/minecraft/OpSys.h"
|
|
#include "GradleSpecifier.h"
|
|
#include "logic/net/URLConstants.h"
|
|
|
|
class RawLibrary;
|
|
typedef std::shared_ptr<RawLibrary> RawLibraryPtr;
|
|
|
|
class RawLibrary
|
|
{
|
|
friend class OneSixLibrary;
|
|
public: /* methods */
|
|
/// read and create a basic library
|
|
static RawLibraryPtr fromJson(const QJsonObject &libObj, const QString &filename);
|
|
|
|
/// read and create a MultiMC '+' library. Those have some extra fields.
|
|
static RawLibraryPtr fromJsonPlus(const QJsonObject &libObj, const QString &filename);
|
|
|
|
/// Convert the library back to an JSON object
|
|
QJsonObject toJson() const;
|
|
|
|
/// Returns the raw name field
|
|
const GradleSpecifier & rawName() const
|
|
{
|
|
return m_name;
|
|
}
|
|
|
|
void setRawName(const GradleSpecifier & spec)
|
|
{
|
|
m_name = spec;
|
|
}
|
|
|
|
void setClassifier(const QString & spec)
|
|
{
|
|
m_name.setClassifier(spec);
|
|
}
|
|
|
|
/// returns the full group and artifact prefix
|
|
QString artifactPrefix() const
|
|
{
|
|
return m_name.artifactPrefix();
|
|
}
|
|
|
|
/// get the artifact ID
|
|
QString artifactId() const
|
|
{
|
|
return m_name.artifactId();
|
|
}
|
|
|
|
/// get the artifact version
|
|
QString version() const
|
|
{
|
|
return m_name.version();
|
|
}
|
|
|
|
/// Returns true if the library is native
|
|
bool isNative() const
|
|
{
|
|
return m_native_classifiers.size() != 0;
|
|
}
|
|
|
|
/// Set the url base for downloads
|
|
void setBaseUrl(const QString &base_url)
|
|
{
|
|
m_base_url = base_url;
|
|
}
|
|
|
|
/// List of files this library describes. Required because of platform-specificness of native libs
|
|
QStringList files() const;
|
|
|
|
/// List Shortcut for checking if all the above files exist
|
|
bool filesExist(const QDir &base) const;
|
|
|
|
void setAbsoluteUrl(const QString &absolute_url)
|
|
{
|
|
m_absolute_url = absolute_url;
|
|
}
|
|
|
|
QString absoluteUrl() const
|
|
{
|
|
return m_absolute_url;
|
|
}
|
|
|
|
void setHint(const QString &hint)
|
|
{
|
|
m_hint = hint;
|
|
}
|
|
|
|
QString hint() const
|
|
{
|
|
return m_hint;
|
|
}
|
|
|
|
/// Set the load rules
|
|
void setRules(QList<std::shared_ptr<Rule>> rules)
|
|
{
|
|
m_rules = rules;
|
|
}
|
|
|
|
/// Returns true if the library should be loaded (or extracted, in case of natives)
|
|
bool isActive() const;
|
|
|
|
/// Get the URL to download the library from
|
|
QString downloadUrl() const;
|
|
|
|
/// Get the relative path where the library should be saved
|
|
QString storagePath() const;
|
|
|
|
|
|
protected: /* data */
|
|
/// the basic gradle dependency specifier.
|
|
GradleSpecifier m_name;
|
|
/// where to store the lib locally
|
|
QString m_storage_path;
|
|
/// is this lib actually active on the current OS?
|
|
bool m_is_active = false;
|
|
|
|
|
|
public: /* data */
|
|
// TODO: make all of these protected, clean up semantics of implicit vs. explicit values.
|
|
/// URL where the file can be downloaded
|
|
QString m_base_url;
|
|
|
|
/// DEPRECATED: absolute URL. takes precedence the normal download URL, if defined
|
|
QString m_absolute_url;
|
|
|
|
/// type hint - modifies how the library is treated
|
|
QString m_hint;
|
|
|
|
/// true if the library had an extract/excludes section (even empty)
|
|
bool applyExcludes = false;
|
|
|
|
/// a list of files that shouldn't be extracted from the library
|
|
QStringList extract_excludes;
|
|
|
|
/// native suffixes per OS
|
|
QMap<OpSys, QString> m_native_classifiers;
|
|
|
|
/// true if the library had a rules section (even empty)
|
|
bool applyRules = false;
|
|
|
|
/// rules associated with the library
|
|
QList<std::shared_ptr<Rule>> m_rules;
|
|
|
|
/// used for '+' libraries, determines how to add them
|
|
enum InsertType
|
|
{
|
|
Apply,
|
|
Append,
|
|
Prepend,
|
|
Replace
|
|
} insertType = Append;
|
|
QString insertData;
|
|
|
|
/// determines how can libraries be applied. conflicting dependencies cause errors.
|
|
enum DependType
|
|
{
|
|
Soft, //! needs equal or newer version
|
|
Hard //! needs equal version (different versions mean version conflict)
|
|
} dependType = Soft;
|
|
};
|