mirror of
https://github.com/overte-org/overte.git
synced 2025-04-26 08:36:26 +02:00
121 lines
4.7 KiB
C++
121 lines
4.7 KiB
C++
//
|
|
// ScriptUUID.h
|
|
// libraries/script-engine/src/
|
|
//
|
|
// Created by Andrew Meadows on 2014-04-07
|
|
// Copyright (c) 2014 High Fidelity, Inc. All rights reserved.
|
|
//
|
|
// Scriptable interface for a UUID helper class object. Used exclusively in the JavaScript API
|
|
//
|
|
// Distributed under the Apache License, Version 2.0.
|
|
// See the accompanying file LICENSE or http://www.apache.org/licenses/LICENSE-2.0.html
|
|
//
|
|
|
|
#ifndef hifi_ScriptUUID_h
|
|
#define hifi_ScriptUUID_h
|
|
|
|
#include <QUuid>
|
|
#include <QtScript/QScriptable>
|
|
|
|
/**jsdoc
|
|
* A UUID (Universally Unique IDentifier) is used to uniquely identify entities, overlays, avatars, and the like. It is
|
|
* represented in JavaScript as a string in the format, <code>{nnnnnnnn-nnnn-nnnn-nnnn-nnnnnnnnnnnn}</code>, where the "n"s are
|
|
* hexadecimal digits.
|
|
*
|
|
* @namespace Uuid
|
|
* @property NULL {Uuid} The null UUID, <code>{00000000-0000-0000-0000-000000000000}</code>.
|
|
*/
|
|
|
|
/// Scriptable interface for a UUID helper class object. Used exclusively in the JavaScript API
|
|
class ScriptUUID : public QObject, protected QScriptable {
|
|
Q_OBJECT
|
|
Q_PROPERTY(QString NULL READ NULL_UUID CONSTANT) // String for use in scripts.
|
|
|
|
public slots:
|
|
/**jsdoc
|
|
* Generates a UUID from a string representation of the UUID.
|
|
* @function Uuid.fromString
|
|
* @param {string} string - A string representation of a UUID. The curly braces are optional.
|
|
* @returns {Uuid} A UUID if the given <code>string</code> is valid, <code>null</code> otherwise.
|
|
* @example <caption>Valid and invalid parameters.</caption>
|
|
* var uuid = Uuid.fromString("{527c27ea-6d7b-4b47-9ae2-b3051d50d2cd}");
|
|
* print(uuid); // {527c27ea-6d7b-4b47-9ae2-b3051d50d2cd}
|
|
*
|
|
* uuid = Uuid.fromString("527c27ea-6d7b-4b47-9ae2-b3051d50d2cd");
|
|
* print(uuid); // {527c27ea-6d7b-4b47-9ae2-b3051d50d2cd}
|
|
*
|
|
* uuid = Uuid.fromString("527c27ea");
|
|
* print(uuid); // null
|
|
*/
|
|
QUuid fromString(const QString& string);
|
|
|
|
/**jsdoc
|
|
* Generates a string representation of a UUID. However, because UUIDs are represented in JavaScript as strings, this is in
|
|
* effect a no-op.
|
|
* @function Uuid.toString
|
|
* @param {Uuid} id - The UUID to generate a string from.
|
|
* @returns {string} - A string representation of the UUID.
|
|
*/
|
|
QString toString(const QUuid& id);
|
|
|
|
/**jsdoc
|
|
* Generate a new UUID.
|
|
* @function Uuid.generate
|
|
* @returns {Uuid} A new UUID.
|
|
* @example <caption>Generate a new UUID and reports its JavaScript type.</caption>
|
|
* var uuid = Uuid.generate();
|
|
* print(uuid); // {nnnnnnnn-nnnn-nnnn-nnnn-nnnnnnnnnnnn}
|
|
* print(typeof uuid); // string
|
|
*/
|
|
QUuid generate();
|
|
|
|
/**jsdoc
|
|
* Test whether two given UUIDs are equal.
|
|
* @function Uuid.isEqual
|
|
* @param {Uuid} idA - The first UUID to compare.
|
|
* @param {Uuid} idB - The second UUID to compare.
|
|
* @returns {boolean} <code>true</code> if the two UUIDs are equal, otherwise <code>false</code>.
|
|
* @example <caption>Demonstrate <code>true</code> and <code>false</code> cases.</caption>
|
|
* var uuidA = Uuid.generate();
|
|
* var uuidB = Uuid.generate();
|
|
* print(Uuid.isEqual(uuidA, uuidB)); // false
|
|
* uuidB = uuidA;
|
|
* print(Uuid.isEqual(uuidA, uuidB)); // true
|
|
*/
|
|
bool isEqual(const QUuid& idA, const QUuid& idB);
|
|
|
|
/**jsdoc
|
|
* Test whether a given UUID is null.
|
|
* @function Uuid.isNull
|
|
* @param {Uuid} id - The UUID to test.
|
|
* @returns {boolean} <code>true</code> if the UUID equals Uuid.NULL or is <code>null</code>, otherwise <code>false</code>.
|
|
* @example <caption>Demonstrate <code>true</code> and <code>false</code> cases.</caption>
|
|
* var uuid; // undefined
|
|
* print(Uuid.isNull(uuid)); // false
|
|
* uuid = Uuid.generate();
|
|
* print(Uuid.isNull(uuid)); // false
|
|
* uuid = Uuid.NULL;
|
|
* print(Uuid.isNull(uuid)); // true
|
|
* uuid = null;
|
|
* print(Uuid.isNull(uuid)); // true
|
|
*/
|
|
bool isNull(const QUuid& id);
|
|
|
|
/**jsdoc
|
|
* Print to the program log a text label followed by the UUID value.
|
|
* @function Uuid.print
|
|
* @param {string} label - The label to print.
|
|
* @param {Uuid} id - The UUID to print.
|
|
* @example <caption>Two ways of printing a label plus UUID.</caption>
|
|
* var uuid = Uuid.generate();
|
|
* Uuid.print("Generated UUID:", uuid); // Generated UUID: {nnnnnnnn-nnnn-nnnn-nnnn-nnnnnnnnnnnn}
|
|
* print("Generated UUID: " + uuid); // Generated UUID: {nnnnnnnn-nnnn-nnnn-nnnn-nnnnnnnnnnnn}
|
|
*/
|
|
void print(const QString& label, const QUuid& id);
|
|
|
|
private:
|
|
const QString NULL_UUID() { return NULL_ID; }
|
|
const QString NULL_ID { "{00000000-0000-0000-0000-000000000000}" };
|
|
};
|
|
|
|
#endif // hifi_ScriptUUID_h
|