summaryrefslogtreecommitdiff
path: root/includes/js/dojox/uuid
diff options
context:
space:
mode:
Diffstat (limited to 'includes/js/dojox/uuid')
-rw-r--r--includes/js/dojox/uuid/README43
-rw-r--r--includes/js/dojox/uuid/Uuid.js200
-rw-r--r--includes/js/dojox/uuid/_base.js245
-rw-r--r--includes/js/dojox/uuid/generateRandomUuid.js56
-rw-r--r--includes/js/dojox/uuid/generateTimeBasedUuid.js290
-rw-r--r--includes/js/dojox/uuid/tests/runTests.html10
-rw-r--r--includes/js/dojox/uuid/tests/uuid.js377
7 files changed, 1221 insertions, 0 deletions
diff --git a/includes/js/dojox/uuid/README b/includes/js/dojox/uuid/README
new file mode 100644
index 0000000..ea6b40e
--- /dev/null
+++ b/includes/js/dojox/uuid/README
@@ -0,0 +1,43 @@
+-------------------------------------------------------------------------------
+DojoX UUID
+-------------------------------------------------------------------------------
+Version 0.9
+Release date: 06/21/2007
+-------------------------------------------------------------------------------
+Project state: stable
+-------------------------------------------------------------------------------
+Project authors
+ Brian Douglas Skinner (skinner@dojotoolkit.org)
+-------------------------------------------------------------------------------
+Project description
+
+DojoX UUID is the port of the original Dojo 0.4.x UUID classes. The UUID
+classes can be used to represent Universally Unique IDentifiers (UUIDs), as
+described in the IETF's RFC 4122:
+ http://tools.ietf.org/html/rfc4122
+
+The DojoX UUID classes provide support for generating both "time-based" UUIDs
+and lightweight "random" UUIDs. DojoX UUID does not yet have support for
+generating new "name-based" UUIDs, but the dojo.uuid.Uuid class can represent
+existing name-based UUIDs, such as UUIDs read from a file or from a server.
+
+-------------------------------------------------------------------------------
+Dependencies:
+
+DojoX UUID has no dependencies, outside of Dojo Core.
+-------------------------------------------------------------------------------
+Documentation
+
+See the API documentation for Dojo (http://dojotoolkit.org/api).
+-------------------------------------------------------------------------------
+Installation instructions
+
+Grab the following from the Dojo SVN Repository:
+http://svn.dojotoolkit.org/var/src/dojo/dojox/trunk/uuid.js
+http://svn.dojotoolkit.org/var/src/dojo/dojox/trunk/uuid/*
+
+Install into the following directory structure:
+/dojox/uuid/
+
+...which should be at the same level as your Dojo checkout.
+-------------------------------------------------------------------------------
diff --git a/includes/js/dojox/uuid/Uuid.js b/includes/js/dojox/uuid/Uuid.js
new file mode 100644
index 0000000..213ecd1
--- /dev/null
+++ b/includes/js/dojox/uuid/Uuid.js
@@ -0,0 +1,200 @@
+if(!dojo._hasResource["dojox.uuid.Uuid"]){ //_hasResource checks added by build. Do not use _hasResource directly in your code.
+dojo._hasResource["dojox.uuid.Uuid"] = true;
+dojo.provide("dojox.uuid.Uuid");
+dojo.require("dojox.uuid");
+
+dojox.uuid.Uuid = function(/*String?*/ input){
+ // summary:
+ // This is the constructor for the Uuid class. The Uuid class offers
+ // methods for inspecting existing UUIDs.
+ // input: A 36-character string that conforms to the UUID spec.
+ // examples:
+ // var uuid;
+ // uuid = new dojox.uuid.Uuid("3b12f1df-5232-4804-897e-917bf397618a");
+ // uuid = new dojox.uuid.Uuid(); // "00000000-0000-0000-0000-000000000000"
+ // uuid = new dojox.uuid.Uuid(dojox.uuid.generateRandomUuid());
+ // uuid = new dojox.uuid.Uuid(dojox.uuid.generateTimeBasedUuid());
+ // dojox.uuid.Uuid.setGenerator(dojox.uuid.generateRandomUuid);
+ // uuid = new dojox.uuid.Uuid();
+ // dojox.uuid.assert(!uuid.isEqual(dojox.uuid.NIL_UUID));
+ this._uuidString = dojox.uuid.NIL_UUID;
+ if(input){
+ dojox.uuid.assert(dojo.isString(input));
+ this._uuidString = input.toLowerCase();
+ dojox.uuid.assert(this.isValid());
+ }else{
+ var ourGenerator = dojox.uuid.Uuid.getGenerator();
+ if(ourGenerator){
+ this._uuidString = ourGenerator();
+ dojox.uuid.assert(this.isValid());
+ }
+ }
+};
+
+dojox.uuid.Uuid.compare = function(/*dojox.uuid.Uuid*/ uuidOne, /*dojox.uuid.Uuid*/ uuidTwo){
+ // summary:
+ // Given two UUIDs to compare, this method returns 0, 1, or -1.
+ // description:
+ // This method is designed to be used by sorting routines, like the
+ // JavaScript built-in Array sort() method. This implementation is
+ // intended to match the sample implementation in IETF RFC 4122:
+ // http://www.ietf.org/rfc/rfc4122.txt
+ // uuidOne: Any object that has toString() method that returns a 36-character string that conforms to the UUID spec.
+ // uuidTwo: Any object that has toString() method that returns a 36-character string that conforms to the UUID spec.
+
+ // examples:
+ // var uuid;
+ // var generator = dojox.uuid.TimeBasedGenerator;
+ // var a = new dojox.uuid.Uuid(generator);
+ // var b = new dojox.uuid.Uuid(generator);
+ // var c = new dojox.uuid.Uuid(generator);
+ // var array = new Array(a, b, c);
+ // array.sort(dojox.uuid.Uuid.compare);
+ var uuidStringOne = uuidOne.toString();
+ var uuidStringTwo = uuidTwo.toString();
+ if (uuidStringOne > uuidStringTwo) return 1; // integer
+ if (uuidStringOne < uuidStringTwo) return -1; // integer
+ return 0; // integer (either 0, 1, or -1)
+};
+
+dojox.uuid.Uuid.setGenerator = function(/*Function?*/ generator){
+ // summary:
+ // Sets the default generator, which will be used by the
+ // "new dojox.uuid.Uuid()" constructor if no parameters
+ // are passed in.
+ // generator: A UUID generator function, such as dojox.uuid.generateTimeBasedUuid.
+ dojox.uuid.assert(!generator || dojo.isFunction(generator));
+ dojox.uuid.Uuid._ourGenerator = generator;
+};
+
+dojox.uuid.Uuid.getGenerator = function(){
+ // summary:
+ // Returns the default generator. See setGenerator().
+ return dojox.uuid.Uuid._ourGenerator; // generator (A UUID generator, such as dojox.uuid.TimeBasedGenerator).
+};
+
+dojox.uuid.Uuid.prototype.toString = function(){
+ // summary:
+ // This method returns a standard 36-character string representing
+ // the UUID, such as "3b12f1df-5232-4804-897e-917bf397618a".
+ return this._uuidString; // string
+};
+
+dojox.uuid.Uuid.prototype.compare = function(/*dojox.uuid.Uuid*/ otherUuid){
+ // summary:
+ // Compares this UUID to another UUID, and returns 0, 1, or -1.
+ // description:
+ // This implementation is intended to match the sample implementation
+ // in IETF RFC 4122: http://www.ietf.org/rfc/rfc4122.txt
+ // otherUuid: Any object that has toString() method that returns a 36-character string that conforms to the UUID spec.
+ return dojox.uuid.Uuid.compare(this, otherUuid); // integer (either 0, 1, or -1)
+};
+
+dojox.uuid.Uuid.prototype.isEqual = function(/*dojox.uuid.Uuid*/ otherUuid){
+ // summary:
+ // Returns true if this UUID is equal to the otherUuid, or false otherwise.
+ // otherUuid: Any object that has toString() method that returns a 36-character string that conforms to the UUID spec.
+ return (this.compare(otherUuid) == 0); // boolean
+};
+
+dojox.uuid.Uuid.prototype.isValid = function(){
+ // summary:
+ // Returns true if the UUID was initialized with a valid value.
+ return dojox.uuid.isValid(this);
+};
+
+dojox.uuid.Uuid.prototype.getVariant = function(){
+ // summary:
+ // Returns a variant code that indicates what type of UUID this is.
+ // Returns one of the enumerated dojox.uuid.variant values.
+
+ // example:
+ // var uuid = new dojox.uuid.Uuid("3b12f1df-5232-4804-897e-917bf397618a");
+ // var variant = uuid.getVariant();
+ // dojox.uuid.assert(variant == dojox.uuid.variant.DCE);
+ // example:
+ // "3b12f1df-5232-4804-897e-917bf397618a"
+ // ^
+ // |
+ // (variant "10__" == DCE)
+ return dojox.uuid.getVariant(this);
+};
+
+dojox.uuid.Uuid.prototype.getVersion = function(){
+ // summary:
+ // Returns a version number that indicates what type of UUID this is.
+ // Returns one of the enumerated dojox.uuid.version values.
+ // example:
+ // var uuid = new dojox.uuid.Uuid("b4308fb0-86cd-11da-a72b-0800200c9a66");
+ // var version = uuid.getVersion();
+ // dojox.uuid.assert(version == dojox.uuid.version.TIME_BASED);
+ // exceptions:
+ // Throws an Error if this is not a DCE Variant UUID.
+ if(!this._versionNumber){
+ this._versionNumber = dojox.uuid.getVersion(this);
+ }
+ return this._versionNumber; // dojox.uuid.version
+};
+
+dojox.uuid.Uuid.prototype.getNode = function(){
+ // summary:
+ // If this is a version 1 UUID (a time-based UUID), getNode() returns a
+ // 12-character string with the "node" or "pseudonode" portion of the UUID,
+ // which is the rightmost 12 characters.
+ // exceptions:
+ // Throws an Error if this is not a version 1 UUID.
+ if (!this._nodeString) {
+ this._nodeString = dojox.uuid.getNode(this);
+ }
+ return this._nodeString; // String (a 12-character string, which will look something like "917bf397618a")
+};
+
+dojox.uuid.Uuid.prototype.getTimestamp = function(/*String?*/ returnType){
+ // summary:
+ // If this is a version 1 UUID (a time-based UUID), this method returns
+ // the timestamp value encoded in the UUID. The caller can ask for the
+ // timestamp to be returned either as a JavaScript Date object or as a
+ // 15-character string of hex digits.
+ // returnType: Any of these five values: "string", String, "hex", "date", Date
+ // returns:
+ // Returns the timestamp value as a JavaScript Date object or a 15-character string of hex digits.
+ // examples:
+ // var uuid = new dojox.uuid.Uuid("b4308fb0-86cd-11da-a72b-0800200c9a66");
+ // var date, string, hexString;
+ // date = uuid.getTimestamp(); // returns a JavaScript Date
+ // date = uuid.getTimestamp(Date); //
+ // string = uuid.getTimestamp(String); // "Mon, 16 Jan 2006 20:21:41 GMT"
+ // hexString = uuid.getTimestamp("hex"); // "1da86cdb4308fb0"
+ // exceptions:
+ // Throws an Error if this is not a version 1 UUID.
+ if(!returnType){returnType = null};
+ switch(returnType){
+ case "string":
+ case String:
+ return this.getTimestamp(Date).toUTCString(); // String (e.g. "Mon, 16 Jan 2006 20:21:41 GMT")
+ break;
+ case "hex":
+ // Return a 15-character string of hex digits containing the
+ // timestamp for this UUID, with the high-order bits first.
+ if (!this._timestampAsHexString) {
+ this._timestampAsHexString = dojox.uuid.getTimestamp(this, "hex");
+ }
+ return this._timestampAsHexString; // String (e.g. "1da86cdb4308fb0")
+ break;
+ case null: // no returnType was specified, so default to Date
+ case "date":
+ case Date:
+ // Return a JavaScript Date object.
+ if (!this._timestampAsDate) {
+ this._timestampAsDate = dojox.uuid.getTimestamp(this, Date);
+ }
+ return this._timestampAsDate; // Date
+ break;
+ default:
+ // we got passed something other than a valid returnType
+ dojox.uuid.assert(false, "The getTimestamp() method dojox.uuid.Uuid was passed a bogus returnType: " + returnType);
+ break;
+ }
+};
+
+}
diff --git a/includes/js/dojox/uuid/_base.js b/includes/js/dojox/uuid/_base.js
new file mode 100644
index 0000000..b65e5da
--- /dev/null
+++ b/includes/js/dojox/uuid/_base.js
@@ -0,0 +1,245 @@
+if(!dojo._hasResource["dojox.uuid._base"]){ //_hasResource checks added by build. Do not use _hasResource directly in your code.
+dojo._hasResource["dojox.uuid._base"] = true;
+dojo.provide("dojox.uuid._base");
+
+// Public constants:
+dojox.uuid.NIL_UUID = "00000000-0000-0000-0000-000000000000";
+dojox.uuid.version = {
+ // Enumeration for the different UUID versions.
+ UNKNOWN: 0,
+ TIME_BASED: 1,
+ DCE_SECURITY: 2,
+ NAME_BASED_MD5: 3,
+ RANDOM: 4,
+ NAME_BASED_SHA1: 5 };
+dojox.uuid.variant = {
+ // Enumeration for the different UUID variants.
+ NCS: "0",
+ DCE: "10",
+ MICROSOFT: "110",
+ UNKNOWN: "111" };
+
+dojox.uuid.assert = function(/*Boolean*/ booleanValue, /*String?*/ message){
+ // summary:
+ // Throws an exception if the assertion fails.
+ // description:
+ // If the asserted condition is true, this method does nothing. If the
+ // condition is false, we throw an error with a error message.
+ // booleanValue: Must be true for the assertion to succeed.
+ // message: A string describing the assertion.
+ // throws: Throws an Error if 'booleanValue' is false.
+ if(!booleanValue){
+ if(!message){
+ message = "An assert statement failed.\n" +
+ "The method dojox.uuid.assert() was called with a 'false' value.\n";
+ }
+ throw new Error(message);
+ }
+};
+
+dojox.uuid.generateNilUuid = function(){
+ // summary:
+ // This function returns the Nil UUID: "00000000-0000-0000-0000-000000000000".
+ // description:
+ // The Nil UUID is described in section 4.1.7 of
+ // RFC 4122: http://tools.ietf.org/html/rfc4122#section-4.1.7
+ // examples:
+ // var string = dojox.uuid.generateNilUuid();
+ return dojox.uuid.NIL_UUID;; // String
+};
+
+dojox.uuid.isValid = function(/*String*/ uuidString){
+ // summary:
+ // Returns true if the UUID was initialized with a valid value.
+ uuidString = uuidString.toString();
+ var valid = (dojo.isString(uuidString) &&
+ (uuidString.length == 36) &&
+ (uuidString == uuidString.toLowerCase()));
+ if(valid){
+ var arrayOfParts = uuidString.split("-");
+ valid = ((arrayOfParts.length == 5) &&
+ (arrayOfParts[0].length == 8) &&
+ (arrayOfParts[1].length == 4) &&
+ (arrayOfParts[2].length == 4) &&
+ (arrayOfParts[3].length == 4) &&
+ (arrayOfParts[4].length == 12));
+ var HEX_RADIX = 16;
+ for (var i in arrayOfParts) {
+ var part = arrayOfParts[i];
+ var integer = parseInt(part, HEX_RADIX);
+ valid = valid && isFinite(integer);
+ }
+ }
+ return valid; // boolean
+};
+
+dojox.uuid.getVariant = function(/*String*/ uuidString){
+ // summary:
+ // Returns a variant code that indicates what type of UUID this is.
+ // Returns one of the enumerated dojox.uuid.variant values.
+ // example:
+ // var variant = dojox.uuid.getVariant("3b12f1df-5232-4804-897e-917bf397618a");
+ // dojox.uuid.assert(variant == dojox.uuid.variant.DCE);
+ // example:
+ // "3b12f1df-5232-4804-897e-917bf397618a"
+ // ^
+ // |
+ // (variant "10__" == DCE)
+ if(!dojox.uuid._ourVariantLookupTable){
+ var variant = dojox.uuid.variant;
+ var lookupTable = [];
+
+ lookupTable[0x0] = variant.NCS; // 0000
+ lookupTable[0x1] = variant.NCS; // 0001
+ lookupTable[0x2] = variant.NCS; // 0010
+ lookupTable[0x3] = variant.NCS; // 0011
+
+ lookupTable[0x4] = variant.NCS; // 0100
+ lookupTable[0x5] = variant.NCS; // 0101
+ lookupTable[0x6] = variant.NCS; // 0110
+ lookupTable[0x7] = variant.NCS; // 0111
+
+ lookupTable[0x8] = variant.DCE; // 1000
+ lookupTable[0x9] = variant.DCE; // 1001
+ lookupTable[0xA] = variant.DCE; // 1010
+ lookupTable[0xB] = variant.DCE; // 1011
+
+ lookupTable[0xC] = variant.MICROSOFT; // 1100
+ lookupTable[0xD] = variant.MICROSOFT; // 1101
+ lookupTable[0xE] = variant.UNKNOWN; // 1110
+ lookupTable[0xF] = variant.UNKNOWN; // 1111
+
+ dojox.uuid._ourVariantLookupTable = lookupTable;
+ }
+
+ uuidString = uuidString.toString();
+ var variantCharacter = uuidString.charAt(19);
+ var HEX_RADIX = 16;
+ var variantNumber = parseInt(variantCharacter, HEX_RADIX);
+ dojox.uuid.assert((variantNumber >= 0) && (variantNumber <= 16));
+ return dojox.uuid._ourVariantLookupTable[variantNumber]; // dojox.uuid.variant
+};
+
+dojox.uuid.getVersion = function(/*String*/ uuidString){
+ // summary:
+ // Returns a version number that indicates what type of UUID this is.
+ // Returns one of the enumerated dojox.uuid.version values.
+ // example:
+ // var version = dojox.uuid.getVersion("b4308fb0-86cd-11da-a72b-0800200c9a66");
+ // dojox.uuid.assert(version == dojox.uuid.version.TIME_BASED);
+ // exceptions:
+ // Throws an Error if this is not a DCE Variant UUID.
+ var errorMessage = "dojox.uuid.getVersion() was not passed a DCE Variant UUID.";
+ dojox.uuid.assert(dojox.uuid.getVariant(uuidString) == dojox.uuid.variant.DCE, errorMessage);
+ uuidString = uuidString.toString();
+
+ // "b4308fb0-86cd-11da-a72b-0800200c9a66"
+ // ^
+ // |
+ // (version 1 == TIME_BASED)
+ var versionCharacter = uuidString.charAt(14);
+ var HEX_RADIX = 16;
+ var versionNumber = parseInt(versionCharacter, HEX_RADIX);
+ return versionNumber; // dojox.uuid.version
+};
+
+dojox.uuid.getNode = function(/*String*/ uuidString){
+ // summary:
+ // If this is a version 1 UUID (a time-based UUID), getNode() returns a
+ // 12-character string with the "node" or "pseudonode" portion of the UUID,
+ // which is the rightmost 12 characters.
+ // exceptions:
+ // Throws an Error if this is not a version 1 UUID.
+ var errorMessage = "dojox.uuid.getNode() was not passed a TIME_BASED UUID.";
+ dojox.uuid.assert(dojox.uuid.getVersion(uuidString) == dojox.uuid.version.TIME_BASED, errorMessage);
+
+ uuidString = uuidString.toString();
+ var arrayOfStrings = uuidString.split('-');
+ var nodeString = arrayOfStrings[4];
+ return nodeString; // String (a 12-character string, which will look something like "917bf397618a")
+};
+
+dojox.uuid.getTimestamp = function(/*String*/ uuidString, /*String?*/ returnType){
+ // summary:
+ // If this is a version 1 UUID (a time-based UUID), this method returns
+ // the timestamp value encoded in the UUID. The caller can ask for the
+ // timestamp to be returned either as a JavaScript Date object or as a
+ // 15-character string of hex digits.
+ // returnType: Any of these five values: "string", String, "hex", "date", Date
+ // returns:
+ // Returns the timestamp value as a JavaScript Date object or a 15-character string of hex digits.
+ // examples:
+ // var uuidString = "b4308fb0-86cd-11da-a72b-0800200c9a66";
+ // var date, string, hexString;
+ // date = dojox.uuid.getTimestamp(uuidString); // returns a JavaScript Date
+ // date = dojox.uuid.getTimestamp(uuidString, Date); //
+ // string = dojox.uuid.getTimestamp(uuidString, String); // "Mon, 16 Jan 2006 20:21:41 GMT"
+ // hexString = dojox.uuid.getTimestamp(uuidString, "hex"); // "1da86cdb4308fb0"
+ // exceptions:
+ // Throws an Error if this is not a version 1 UUID.
+ var errorMessage = "dojox.uuid.getTimestamp() was not passed a TIME_BASED UUID.";
+ dojox.uuid.assert(dojox.uuid.getVersion(uuidString) == dojox.uuid.version.TIME_BASED, errorMessage);
+
+ uuidString = uuidString.toString();
+ if(!returnType){returnType = null};
+ switch(returnType){
+ case "string":
+ case String:
+ return dojox.uuid.getTimestamp(uuidString, Date).toUTCString(); // String (e.g. "Mon, 16 Jan 2006 20:21:41 GMT")
+ break;
+ case "hex":
+ // Return a 15-character string of hex digits containing the
+ // timestamp for this UUID, with the high-order bits first.
+ var arrayOfStrings = uuidString.split('-');
+ var hexTimeLow = arrayOfStrings[0];
+ var hexTimeMid = arrayOfStrings[1];
+ var hexTimeHigh = arrayOfStrings[2];
+
+ // Chop off the leading "1" character, which is the UUID
+ // version number for time-based UUIDs.
+ hexTimeHigh = hexTimeHigh.slice(1);
+
+ var timestampAsHexString = hexTimeHigh + hexTimeMid + hexTimeLow;
+ dojox.uuid.assert(timestampAsHexString.length == 15);
+ return timestampAsHexString; // String (e.g. "1da86cdb4308fb0")
+ break;
+ case null: // no returnType was specified, so default to Date
+ case "date":
+ case Date:
+ // Return a JavaScript Date object.
+ var GREGORIAN_CHANGE_OFFSET_IN_HOURS = 3394248;
+ var HEX_RADIX = 16;
+
+ var arrayOfParts = uuidString.split('-');
+ var timeLow = parseInt(arrayOfParts[0], HEX_RADIX);
+ var timeMid = parseInt(arrayOfParts[1], HEX_RADIX);
+ var timeHigh = parseInt(arrayOfParts[2], HEX_RADIX);
+ var hundredNanosecondIntervalsSince1582 = timeHigh & 0x0FFF;
+ hundredNanosecondIntervalsSince1582 <<= 16;
+ hundredNanosecondIntervalsSince1582 += timeMid;
+ // What we really want to do next is shift left 32 bits, but the
+ // result will be too big to fit in an int, so we'll multiply by 2^32,
+ // and the result will be a floating point approximation.
+ hundredNanosecondIntervalsSince1582 *= 0x100000000;
+ hundredNanosecondIntervalsSince1582 += timeLow;
+ var millisecondsSince1582 = hundredNanosecondIntervalsSince1582 / 10000;
+
+ // Again, this will be a floating point approximation.
+ // We can make things exact later if we need to.
+ var secondsPerHour = 60 * 60;
+ var hoursBetween1582and1970 = GREGORIAN_CHANGE_OFFSET_IN_HOURS;
+ var secondsBetween1582and1970 = hoursBetween1582and1970 * secondsPerHour;
+ var millisecondsBetween1582and1970 = secondsBetween1582and1970 * 1000;
+ var millisecondsSince1970 = millisecondsSince1582 - millisecondsBetween1582and1970;
+
+ var timestampAsDate = new Date(millisecondsSince1970);
+ return timestampAsDate; // Date
+ break;
+ default:
+ // we got passed something other than a valid returnType
+ dojox.uuid.assert(false, "dojox.uuid.getTimestamp was not passed a valid returnType: " + returnType);
+ break;
+ }
+};
+
+}
diff --git a/includes/js/dojox/uuid/generateRandomUuid.js b/includes/js/dojox/uuid/generateRandomUuid.js
new file mode 100644
index 0000000..ec590e9
--- /dev/null
+++ b/includes/js/dojox/uuid/generateRandomUuid.js
@@ -0,0 +1,56 @@
+if(!dojo._hasResource["dojox.uuid.generateRandomUuid"]){ //_hasResource checks added by build. Do not use _hasResource directly in your code.
+dojo._hasResource["dojox.uuid.generateRandomUuid"] = true;
+dojo.provide("dojox.uuid.generateRandomUuid");
+
+dojox.uuid.generateRandomUuid = function(){
+ // summary:
+ // This function generates random UUIDs, meaning "version 4" UUIDs.
+ // description:
+ // A typical generated value would be something like this:
+ // "3b12f1df-5232-4804-897e-917bf397618a"
+ //
+ // For more information about random UUIDs, see sections 4.4 and
+ // 4.5 of RFC 4122: http://tools.ietf.org/html/rfc4122#section-4.4
+ //
+ // This generator function is designed to be small and fast,
+ // but not necessarily good.
+ //
+ // Small: This generator has a small footprint. Once comments are
+ // stripped, it's only about 25 lines of code, and it doesn't
+ // dojo.require() any other modules.
+ //
+ // Fast: This generator can generate lots of new UUIDs fairly quickly
+ // (at least, more quickly than the other dojo UUID generators).
+ //
+ // Not necessarily good: We use Math.random() as our source
+ // of randomness, which may or may not provide much randomness.
+ // examples:
+ // var string = dojox.uuid.generateRandomUuid();
+ var HEX_RADIX = 16;
+
+ function _generateRandomEightCharacterHexString(){
+ // Make random32bitNumber be a randomly generated floating point number
+ // between 0 and (4,294,967,296 - 1), inclusive.
+ var random32bitNumber = Math.floor( (Math.random() % 1) * Math.pow(2, 32) );
+ var eightCharacterHexString = random32bitNumber.toString(HEX_RADIX);
+ while(eightCharacterHexString.length < 8){
+ eightCharacterHexString = "0" + eightCharacterHexString;
+ }
+ return eightCharacterHexString; // for example: "3B12F1DF"
+ }
+
+ var hyphen = "-";
+ var versionCodeForRandomlyGeneratedUuids = "4"; // 8 == binary2hex("0100")
+ var variantCodeForDCEUuids = "8"; // 8 == binary2hex("1000")
+ var a = _generateRandomEightCharacterHexString();
+ var b = _generateRandomEightCharacterHexString();
+ b = b.substring(0, 4) + hyphen + versionCodeForRandomlyGeneratedUuids + b.substring(5, 8);
+ var c = _generateRandomEightCharacterHexString();
+ c = variantCodeForDCEUuids + c.substring(1, 4) + hyphen + c.substring(4, 8);
+ var d = _generateRandomEightCharacterHexString();
+ var returnValue = a + hyphen + b + hyphen + c + d;
+ returnValue = returnValue.toLowerCase();
+ return returnValue; // String
+};
+
+}
diff --git a/includes/js/dojox/uuid/generateTimeBasedUuid.js b/includes/js/dojox/uuid/generateTimeBasedUuid.js
new file mode 100644
index 0000000..20be9f4
--- /dev/null
+++ b/includes/js/dojox/uuid/generateTimeBasedUuid.js
@@ -0,0 +1,290 @@
+if(!dojo._hasResource["dojox.uuid.generateTimeBasedUuid"]){ //_hasResource checks added by build. Do not use _hasResource directly in your code.
+dojo._hasResource["dojox.uuid.generateTimeBasedUuid"] = true;
+dojo.provide("dojox.uuid.generateTimeBasedUuid");
+
+dojox.uuid.generateTimeBasedUuid = function(/*String?*/ node){
+ // summary:
+ // This function generates time-based UUIDs, meaning "version 1" UUIDs.
+ // description:
+ // For more info, see
+ // http://www.webdav.org/specs/draft-leach-uuids-guids-01.txt
+ // http://www.infonuovo.com/dma/csdocs/sketch/instidid.htm
+ // http://kruithof.xs4all.nl/uuid/uuidgen
+ // http://www.opengroup.org/onlinepubs/009629399/apdxa.htm#tagcjh_20
+ // http://jakarta.apache.org/commons/sandbox/id/apidocs/org/apache/commons/id/uuid/clock/Clock.html
+ // node:
+ // A 12-character hex string representing either a pseudo-node or
+ // hardware-node (an IEEE 802.3 network node). A hardware-node
+ // will be something like "017bf397618a", always with the first bit
+ // being 0. A pseudo-node will be something like "f17bf397618a",
+ // always with the first bit being 1.
+ // examples:
+ // string = dojox.uuid.generateTimeBasedUuid();
+ // string = dojox.uuid.generateTimeBasedUuid("017bf397618a");
+ // dojox.uuid.generateTimeBasedUuid.setNode("017bf397618a");
+ // string = dojox.uuid.generateTimeBasedUuid(); // the generated UUID has node == "017bf397618a"
+ var uuidString = dojox.uuid.generateTimeBasedUuid._generator.generateUuidString(node);
+ return uuidString; // String
+};
+
+dojox.uuid.generateTimeBasedUuid.isValidNode = function(/*String?*/ node){
+ var HEX_RADIX = 16;
+ var integer = parseInt(node, HEX_RADIX);
+ var valid = dojo.isString(node) && node.length == 12 && isFinite(integer);
+ return valid; // Boolean
+};
+
+dojox.uuid.generateTimeBasedUuid.setNode = function(/*String?*/ node){
+ // summary:
+ // Sets the 'node' value that will be included in generated UUIDs.
+ // node: A 12-character hex string representing a pseudoNode or hardwareNode.
+ dojox.uuid.assert((node === null) || this.isValidNode(node));
+ this._uniformNode = node;
+};
+
+dojox.uuid.generateTimeBasedUuid.getNode = function(){
+ // summary:
+ // Returns the 'node' value that will be included in generated UUIDs.
+ return this._uniformNode; // String (a 12-character hex string representing a pseudoNode or hardwareNode)
+};
+
+
+dojox.uuid.generateTimeBasedUuid._generator = new function(){
+ // Number of hours between October 15, 1582 and January 1, 1970:
+ this.GREGORIAN_CHANGE_OFFSET_IN_HOURS = 3394248;
+
+ // Number of seconds between October 15, 1582 and January 1, 1970:
+ // dojox.uuid.generateTimeBasedUuid.GREGORIAN_CHANGE_OFFSET_IN_SECONDS = 12219292800;
+
+ // --------------------------------------------------
+ // Private variables:
+ var _uuidPseudoNodeString = null;
+ var _uuidClockSeqString = null;
+ var _dateValueOfPreviousUuid = null;
+ var _nextIntraMillisecondIncrement = 0;
+ var _cachedMillisecondsBetween1582and1970 = null;
+ var _cachedHundredNanosecondIntervalsPerMillisecond = null;
+
+ // --------------------------------------------------
+ // Private constants:
+ var HEX_RADIX = 16;
+
+ function _carry(/* array */ arrayA){
+ // summary:
+ // Given an array which holds a 64-bit number broken into 4 16-bit
+ // elements, this method carries any excess bits (greater than 16-bits)
+ // from each array element into the next.
+ // arrayA: An array with 4 elements, each of which is a 16-bit number.
+ arrayA[2] += arrayA[3] >>> 16;
+ arrayA[3] &= 0xFFFF;
+ arrayA[1] += arrayA[2] >>> 16;
+ arrayA[2] &= 0xFFFF;
+ arrayA[0] += arrayA[1] >>> 16;
+ arrayA[1] &= 0xFFFF;
+ dojox.uuid.assert((arrayA[0] >>> 16) === 0);
+ }
+
+ function _get64bitArrayFromFloat(/* float */ x){
+ // summary:
+ // Given a floating point number, this method returns an array which
+ // holds a 64-bit number broken into 4 16-bit elements.
+ var result = new Array(0, 0, 0, 0);
+ result[3] = x % 0x10000;
+ x -= result[3];
+ x /= 0x10000;
+ result[2] = x % 0x10000;
+ x -= result[2];
+ x /= 0x10000;
+ result[1] = x % 0x10000;
+ x -= result[1];
+ x /= 0x10000;
+ result[0] = x;
+ return result; // Array with 4 elements, each of which is a 16-bit number.
+ }
+
+ function _addTwo64bitArrays(/* array */ arrayA, /* array */ arrayB){
+ // summary:
+ // Takes two arrays, each of which holds a 64-bit number broken into 4
+ // 16-bit elements, and returns a new array that holds a 64-bit number
+ // that is the sum of the two original numbers.
+ // arrayA: An array with 4 elements, each of which is a 16-bit number.
+ // arrayB: An array with 4 elements, each of which is a 16-bit number.
+ dojox.uuid.assert(dojo.isArray(arrayA));
+ dojox.uuid.assert(dojo.isArray(arrayB));
+ dojox.uuid.assert(arrayA.length == 4);
+ dojox.uuid.assert(arrayB.length == 4);
+
+ var result = new Array(0, 0, 0, 0);
+ result[3] = arrayA[3] + arrayB[3];
+ result[2] = arrayA[2] + arrayB[2];
+ result[1] = arrayA[1] + arrayB[1];
+ result[0] = arrayA[0] + arrayB[0];
+ _carry(result);
+ return result; // Array with 4 elements, each of which is a 16-bit number.
+ }
+
+ function _multiplyTwo64bitArrays(/* array */ arrayA, /* array */ arrayB){
+ // summary:
+ // Takes two arrays, each of which holds a 64-bit number broken into 4
+ // 16-bit elements, and returns a new array that holds a 64-bit number
+ // that is the product of the two original numbers.
+ // arrayA: An array with 4 elements, each of which is a 16-bit number.
+ // arrayB: An array with 4 elements, each of which is a 16-bit number.
+ dojox.uuid.assert(dojo.isArray(arrayA));
+ dojox.uuid.assert(dojo.isArray(arrayB));
+ dojox.uuid.assert(arrayA.length == 4);
+ dojox.uuid.assert(arrayB.length == 4);
+
+ var overflow = false;
+ if(arrayA[0] * arrayB[0] !== 0){ overflow = true; }
+ if(arrayA[0] * arrayB[1] !== 0){ overflow = true; }
+ if(arrayA[0] * arrayB[2] !== 0){ overflow = true; }
+ if(arrayA[1] * arrayB[0] !== 0){ overflow = true; }
+ if(arrayA[1] * arrayB[1] !== 0){ overflow = true; }
+ if(arrayA[2] * arrayB[0] !== 0){ overflow = true; }
+ dojox.uuid.assert(!overflow);
+
+ var result = new Array(0, 0, 0, 0);
+ result[0] += arrayA[0] * arrayB[3];
+ _carry(result);
+ result[0] += arrayA[1] * arrayB[2];
+ _carry(result);
+ result[0] += arrayA[2] * arrayB[1];
+ _carry(result);
+ result[0] += arrayA[3] * arrayB[0];
+ _carry(result);
+ result[1] += arrayA[1] * arrayB[3];
+ _carry(result);
+ result[1] += arrayA[2] * arrayB[2];
+ _carry(result);
+ result[1] += arrayA[3] * arrayB[1];
+ _carry(result);
+ result[2] += arrayA[2] * arrayB[3];
+ _carry(result);
+ result[2] += arrayA[3] * arrayB[2];
+ _carry(result);
+ result[3] += arrayA[3] * arrayB[3];
+ _carry(result);
+ return result; // Array with 4 elements, each of which is a 16-bit number.
+ }
+
+ function _padWithLeadingZeros(/* string */ string, /* int */ desiredLength){
+ // summary:
+ // Pads a string with leading zeros and returns the result.
+ // string: A string to add padding to.
+ // desiredLength: The number of characters the return string should have.
+
+ // examples:
+ // result = _padWithLeadingZeros("abc", 6);
+ // dojox.uuid.assert(result == "000abc");
+ while(string.length < desiredLength){
+ string = "0" + string;
+ }
+ return string; // string
+ }
+
+ function _generateRandomEightCharacterHexString() {
+ // summary:
+ // Returns a randomly generated 8-character string of hex digits.
+
+ // FIXME: This probably isn't a very high quality random number.
+
+ // Make random32bitNumber be a randomly generated floating point number
+ // between 0 and (4,294,967,296 - 1), inclusive.
+ var random32bitNumber = Math.floor( (Math.random() % 1) * Math.pow(2, 32) );
+
+ var eightCharacterString = random32bitNumber.toString(HEX_RADIX);
+ while(eightCharacterString.length < 8){
+ eightCharacterString = "0" + eightCharacterString;
+ }
+ return eightCharacterString; // String (an 8-character hex string)
+ }
+
+ this.generateUuidString = function(/*String?*/ node){
+ // summary:
+ // Generates a time-based UUID, meaning a version 1 UUID.
+ // description:
+ // JavaScript code running in a browser doesn't have access to the
+ // IEEE 802.3 address of the computer, so if a node value isn't
+ // supplied, we generate a random pseudonode value instead.
+ // node: An optional 12-character string to use as the node in the new UUID.
+ if(node){
+ dojox.uuid.assert(dojox.uuid.generateTimeBasedUuid.isValidNode(node));
+ }else{
+ if(dojox.uuid.generateTimeBasedUuid._uniformNode){
+ node = dojox.uuid.generateTimeBasedUuid._uniformNode;
+ }else{
+ if(!_uuidPseudoNodeString){
+ var pseudoNodeIndicatorBit = 0x8000;
+ var random15bitNumber = Math.floor( (Math.random() % 1) * Math.pow(2, 15) );
+ var leftmost4HexCharacters = (pseudoNodeIndicatorBit | random15bitNumber).toString(HEX_RADIX);
+ _uuidPseudoNodeString = leftmost4HexCharacters + _generateRandomEightCharacterHexString();
+ }
+ node = _uuidPseudoNodeString;
+ }
+ }
+ if(!_uuidClockSeqString){
+ var variantCodeForDCEUuids = 0x8000; // 10--------------, i.e. uses only first two of 16 bits.
+ var random14bitNumber = Math.floor( (Math.random() % 1) * Math.pow(2, 14) );
+ _uuidClockSeqString = (variantCodeForDCEUuids | random14bitNumber).toString(HEX_RADIX);
+ }
+
+ // Maybe we should think about trying to make the code more readable to
+ // newcomers by creating a class called "WholeNumber" that encapsulates
+ // the methods and data structures for working with these arrays that
+ // hold 4 16-bit numbers? And then these variables below have names
+ // like "wholeSecondsPerHour" rather than "arraySecondsPerHour"?
+ var now = new Date();
+ var millisecondsSince1970 = now.valueOf(); // milliseconds since midnight 01 January, 1970 UTC.
+ var nowArray = _get64bitArrayFromFloat(millisecondsSince1970);
+ if(!_cachedMillisecondsBetween1582and1970){
+ var arraySecondsPerHour = _get64bitArrayFromFloat(60 * 60);
+ var arrayHoursBetween1582and1970 = _get64bitArrayFromFloat(dojox.uuid.generateTimeBasedUuid._generator.GREGORIAN_CHANGE_OFFSET_IN_HOURS);
+ var arraySecondsBetween1582and1970 = _multiplyTwo64bitArrays(arrayHoursBetween1582and1970, arraySecondsPerHour);
+ var arrayMillisecondsPerSecond = _get64bitArrayFromFloat(1000);
+ _cachedMillisecondsBetween1582and1970 = _multiplyTwo64bitArrays(arraySecondsBetween1582and1970, arrayMillisecondsPerSecond);
+ _cachedHundredNanosecondIntervalsPerMillisecond = _get64bitArrayFromFloat(10000);
+ }
+ var arrayMillisecondsSince1970 = nowArray;
+ var arrayMillisecondsSince1582 = _addTwo64bitArrays(_cachedMillisecondsBetween1582and1970, arrayMillisecondsSince1970);
+ var arrayHundredNanosecondIntervalsSince1582 = _multiplyTwo64bitArrays(arrayMillisecondsSince1582, _cachedHundredNanosecondIntervalsPerMillisecond);
+
+ if(now.valueOf() == _dateValueOfPreviousUuid){
+ arrayHundredNanosecondIntervalsSince1582[3] += _nextIntraMillisecondIncrement;
+ _carry(arrayHundredNanosecondIntervalsSince1582);
+ _nextIntraMillisecondIncrement += 1;
+ if (_nextIntraMillisecondIncrement == 10000) {
+ // If we've gotten to here, it means we've already generated 10,000
+ // UUIDs in this single millisecond, which is the most that the UUID
+ // timestamp field allows for. So now we'll just sit here and wait
+ // for a fraction of a millisecond, so as to ensure that the next
+ // time this method is called there will be a different millisecond
+ // value in the timestamp field.
+ while (now.valueOf() == _dateValueOfPreviousUuid) {
+ now = new Date();
+ }
+ }
+ }else{
+ _dateValueOfPreviousUuid = now.valueOf();
+ _nextIntraMillisecondIncrement = 1;
+ }
+
+ var hexTimeLowLeftHalf = arrayHundredNanosecondIntervalsSince1582[2].toString(HEX_RADIX);
+ var hexTimeLowRightHalf = arrayHundredNanosecondIntervalsSince1582[3].toString(HEX_RADIX);
+ var hexTimeLow = _padWithLeadingZeros(hexTimeLowLeftHalf, 4) + _padWithLeadingZeros(hexTimeLowRightHalf, 4);
+ var hexTimeMid = arrayHundredNanosecondIntervalsSince1582[1].toString(HEX_RADIX);
+ hexTimeMid = _padWithLeadingZeros(hexTimeMid, 4);
+ var hexTimeHigh = arrayHundredNanosecondIntervalsSince1582[0].toString(HEX_RADIX);
+ hexTimeHigh = _padWithLeadingZeros(hexTimeHigh, 3);
+ var hyphen = "-";
+ var versionCodeForTimeBasedUuids = "1"; // binary2hex("0001")
+ var resultUuid = hexTimeLow + hyphen + hexTimeMid + hyphen +
+ versionCodeForTimeBasedUuids + hexTimeHigh + hyphen +
+ _uuidClockSeqString + hyphen + node;
+ resultUuid = resultUuid.toLowerCase();
+ return resultUuid; // String (a 36 character string, which will look something like "b4308fb0-86cd-11da-a72b-0800200c9a66")
+ }
+
+}();
+
+}
diff --git a/includes/js/dojox/uuid/tests/runTests.html b/includes/js/dojox/uuid/tests/runTests.html
new file mode 100644
index 0000000..41ba177
--- /dev/null
+++ b/includes/js/dojox/uuid/tests/runTests.html
@@ -0,0 +1,10 @@
+<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.0 Transitional//EN">
+<html>
+ <head>
+ <title>Dojox.uuid Unit Test Runner</title>
+ <meta http-equiv="REFRESH" content="0;url=../../../util/doh/runner.html?testModule=dojox.uuid.tests.uuid">
+ </head>
+ <body>
+ Redirecting to D.O.H runner.
+ </body>
+</html>
diff --git a/includes/js/dojox/uuid/tests/uuid.js b/includes/js/dojox/uuid/tests/uuid.js
new file mode 100644
index 0000000..9cc89e0
--- /dev/null
+++ b/includes/js/dojox/uuid/tests/uuid.js
@@ -0,0 +1,377 @@
+if(!dojo._hasResource["dojox.uuid.tests.uuid"]){ //_hasResource checks added by build. Do not use _hasResource directly in your code.
+dojo._hasResource["dojox.uuid.tests.uuid"] = true;
+dojo.provide("dojox.uuid.tests.uuid");
+dojo.require("dojox.uuid");
+dojo.require("dojox.uuid.Uuid");
+dojo.require("dojox.uuid.generateRandomUuid");
+dojo.require("dojox.uuid.generateTimeBasedUuid");
+
+dojox.uuid.tests.uuid.checkValidityOfUuidString = function(/*String*/uuidString){
+ // summary:
+ // A helper function that's used by the registered test functions
+ var NIL_UUID = "00000000-0000-0000-0000-000000000000";
+ if (uuidString == NIL_UUID) {
+ // We'll consider the Nil UUID to be valid, so now
+ // we can just return, with not further checks.
+ return;
+ }
+
+ doh.assertTrue(uuidString.length == 36); // UUIDs have 36 characters
+
+ var validCharacters = "0123456789abcedfABCDEF-";
+ var character;
+ var position;
+ for(var i = 0; i < 36; ++i){
+ character = uuidString.charAt(i);
+ position = validCharacters.indexOf(character);
+ doh.assertTrue(position != -1); // UUIDs have only valid characters
+ }
+
+ var arrayOfParts = uuidString.split("-");
+ doh.assertTrue(arrayOfParts.length == 5); // UUIDs have 5 sections separated by 4 hyphens
+ doh.assertTrue(arrayOfParts[0].length == 8); // Section 0 has 8 characters
+ doh.assertTrue(arrayOfParts[1].length == 4); // Section 1 has 4 characters
+ doh.assertTrue(arrayOfParts[2].length == 4); // Section 2 has 4 characters
+ doh.assertTrue(arrayOfParts[3].length == 4); // Section 3 has 4 characters
+ doh.assertTrue(arrayOfParts[4].length == 12); // Section 4 has 8 characters
+
+ // check to see that the "UUID variant code" starts with the binary bits '10'
+ var section3 = arrayOfParts[3];
+ var HEX_RADIX = 16;
+ var hex3 = parseInt(section3, HEX_RADIX);
+ var binaryString = hex3.toString(2);
+ // alert("section3 = " + section3 + "\n binaryString = " + binaryString);
+ doh.assertTrue(binaryString.length == 16); // section 3 has 16 bits
+ doh.assertTrue(binaryString.charAt(0) == '1'); // first bit of section 3 is 1
+ doh.assertTrue(binaryString.charAt(1) == '0'); // second bit of section 3 is 0
+}
+
+dojox.uuid.tests.uuid.checkValidityOfTimeBasedUuidString = function(/*String*/uuidString){
+ // summary:
+ // A helper function that's used by the registered test functions
+ dojox.uuid.tests.uuid.checkValidityOfUuidString(uuidString);
+ var arrayOfParts = uuidString.split("-");
+ var section2 = arrayOfParts[2];
+ doh.assertTrue(section2.charAt(0) == "1"); // Section 2 starts with a 1
+}
+
+dojox.uuid.tests.uuid.checkForPseudoNodeBitInTimeBasedUuidString = function(/*String*/uuidString){
+ // summary:
+ // A helper function that's used by the registered test functions
+ var arrayOfParts = uuidString.split("-");
+ var section4 = arrayOfParts[4];
+ var firstChar = section4.charAt(0);
+ var HEX_RADIX = 16;
+ var hexFirstChar = parseInt(firstChar, HEX_RADIX);
+ var binaryString = hexFirstChar.toString(2);
+ var firstBit;
+ if(binaryString.length == 4){
+ firstBit = binaryString.charAt(0);
+ }else{
+ firstBit = '0';
+ }
+ doh.assertTrue(firstBit == '1'); // first bit of section 4 is 1
+}
+
+doh.register("dojox.uuid.tests.uuid",
+ [
+ /*
+ function test_uuid_performance(){
+ var start = new Date();
+ var startMS = start.valueOf();
+ var nowMS = startMS;
+ var i;
+ var now;
+ var numTrials = 100000;
+
+ while(nowMS == startMS){
+ now = new Date();
+ nowMS = now.valueOf();
+ }
+
+ startMS = nowMS;
+ for(i = 0; i < numTrials; ++i){
+ var a = dojox.uuid.LightweightGenerator.generate();
+ }
+ now = new Date();
+ nowMS = now.valueOf();
+ var elapsedMS = nowMS - startMS;
+ // dojo.log.debug("created " + numTrials + " UUIDs in " + elapsedMS + " milliseconds");
+ },
+ */
+
+ function test_uuid_capitalization(){
+ var randomLowercaseString = "3b12f1df-5232-4804-897e-917bf397618a";
+ var randomUppercaseString = "3B12F1DF-5232-4804-897E-917BF397618A";
+
+ var timebasedLowercaseString = "b4308fb0-86cd-11da-a72b-0800200c9a66";
+ var timebasedUppercaseString = "B4308FB0-86CD-11DA-A72B-0800200C9A66";
+
+ var uuidRL = new dojox.uuid.Uuid(randomLowercaseString);
+ var uuidRU = new dojox.uuid.Uuid(randomUppercaseString);
+
+ var uuidTL = new dojox.uuid.Uuid(timebasedLowercaseString);
+ var uuidTU = new dojox.uuid.Uuid(timebasedUppercaseString);
+
+ doh.assertTrue(uuidRL.isEqual(uuidRU));
+ doh.assertTrue(uuidRU.isEqual(uuidRL));
+
+ doh.assertTrue(uuidTL.isEqual(uuidTU));
+ doh.assertTrue(uuidTU.isEqual(uuidTL));
+ },
+
+ function test_uuid_constructor(){
+ var uuid, uuidToo;
+
+ var nilUuid = '00000000-0000-0000-0000-000000000000';
+ uuid = new dojox.uuid.Uuid();
+ doh.assertTrue(uuid == nilUuid); // 'new dojox.uuid.Uuid()' returns the Nil UUID
+
+ var randomUuidString = "3b12f1df-5232-4804-897e-917bf397618a";
+ uuid = new dojox.uuid.Uuid(randomUuidString);
+ doh.assertTrue(uuid.isValid());
+ doh.assertTrue(uuid.getVariant() == dojox.uuid.variant.DCE);
+ doh.assertTrue(uuid.getVersion() == dojox.uuid.version.RANDOM);
+ uuidToo = new dojox.uuid.Uuid(new String(randomUuidString));
+ doh.assertTrue(uuid.isEqual(uuidToo));
+
+ var timeBasedUuidString = "b4308fb0-86cd-11da-a72b-0800200c9a66";
+ uuid = new dojox.uuid.Uuid(timeBasedUuidString);
+ doh.assertTrue(uuid.isValid());
+ doh.assertTrue(uuid.getVariant() == dojox.uuid.variant.DCE);
+ doh.assertTrue(uuid.getVersion() == dojox.uuid.version.TIME_BASED);
+ doh.assertTrue(uuid.getNode() == "0800200c9a66");
+ var timestamp = uuid.getTimestamp();
+ var date = uuid.getTimestamp(Date);
+ var dateString = uuid.getTimestamp(String);
+ var hexString = uuid.getTimestamp("hex");
+ var now = new Date();
+ doh.assertTrue(timestamp.valueOf() == date.valueOf());
+ doh.assertTrue(hexString == "1da86cdb4308fb0");
+ doh.assertTrue(timestamp < now);
+ },
+
+ function test_uuid_generators(){
+ var generators = [
+ dojox.uuid.generateNilUuid,
+ dojox.uuid.generateRandomUuid,
+ dojox.uuid.generateTimeBasedUuid
+ ];
+
+ for(var i in generators){
+ var generator = generators[i];
+ var uuidString = generator();
+
+ doh.assertTrue((typeof uuidString) == 'string');
+ dojox.uuid.tests.uuid.checkValidityOfUuidString(uuidString);
+
+ var uuid = new dojox.uuid.Uuid(uuidString);
+ if(generator != dojox.uuid.generateNilUuid){
+ doh.assertTrue(uuid.getVariant() == dojox.uuid.variant.DCE);
+ }
+
+ doh.assertTrue(uuid.isEqual(uuid));
+ doh.assertTrue(uuid.compare(uuid) == 0);
+ doh.assertTrue(dojox.uuid.Uuid.compare(uuid, uuid) == 0);
+ dojox.uuid.tests.uuid.checkValidityOfUuidString(uuid.toString());
+ doh.assertTrue(uuid.toString().length == 36);
+
+ if(generator != dojox.uuid.generateNilUuid){
+ var uuidStringOne = generator();
+ var uuidStringTwo = generator();
+ doh.assertTrue(uuidStringOne != uuidStringTwo);
+
+ dojox.uuid.Uuid.setGenerator(generator);
+ var uuidOne = new dojox.uuid.Uuid();
+ var uuidTwo = new dojox.uuid.Uuid();
+ doh.assertTrue(generator === dojox.uuid.Uuid.getGenerator());
+ dojox.uuid.Uuid.setGenerator(null);
+ doh.assertTrue(uuidOne != uuidTwo);
+ doh.assertTrue(!uuidOne.isEqual(uuidTwo));
+ doh.assertTrue(!uuidTwo.isEqual(uuidOne));
+
+ var oneVsTwo = dojox.uuid.Uuid.compare(uuidOne, uuidTwo); // either 1 or -1
+ var twoVsOne = dojox.uuid.Uuid.compare(uuidTwo, uuidOne); // either -1 or 1
+ doh.assertTrue(oneVsTwo + twoVsOne == 0);
+ doh.assertTrue(oneVsTwo != 0);
+ doh.assertTrue(twoVsOne != 0);
+
+ doh.assertTrue(!uuidTwo.isEqual(uuidOne));
+ }
+
+ if(generator == dojox.uuid.generateRandomUuid){
+ doh.assertTrue(uuid.getVersion() == dojox.uuid.version.RANDOM);
+ }
+
+ if(generator == dojox.uuid.generateTimeBasedUuid){
+ dojox.uuid.tests.uuid.checkValidityOfTimeBasedUuidString(uuid.toString());
+ doh.assertTrue(uuid.getVersion() == dojox.uuid.version.TIME_BASED);
+ doh.assertTrue(dojo.isString(uuid.getNode()));
+ doh.assertTrue(uuid.getNode().length == 12);
+ var timestamp = uuid.getTimestamp();
+ var date = uuid.getTimestamp(Date);
+ var dateString = uuid.getTimestamp(String);
+ var hexString = uuid.getTimestamp("hex");
+ doh.assertTrue(date instanceof Date);
+ doh.assertTrue(timestamp.valueOf() == date.valueOf());
+ doh.assertTrue(hexString.length == 15);
+ }
+ }
+ },
+
+ function test_uuid_nilGenerator(){
+ var nilUuidString = '00000000-0000-0000-0000-000000000000';
+ var uuidString = dojox.uuid.generateNilUuid();
+ doh.assertTrue(uuidString == nilUuidString);
+ },
+
+ function test_uuid_timeBasedGenerator(){
+ var uuid; // an instance of dojox.uuid.Uuid
+ var string; // a simple string literal
+ var generator = dojox.uuid.generateTimeBasedUuid;
+
+ var string1 = generator();
+ var uuid2 = new dojox.uuid.Uuid(generator());
+ var string3 = generator("017bf397618a"); // hardwareNode
+ var string4 = generator("f17bf397618a"); // pseudoNode
+ var string5 = generator(new String("017BF397618A"));
+
+ dojox.uuid.generateTimeBasedUuid.setNode("017bf397618a");
+ var string6 = generator(); // the generated UUID has node == "017bf397618a"
+ var uuid7 = new dojox.uuid.Uuid(generator()); // the generated UUID has node == "017bf397618a"
+ var returnedNode = dojox.uuid.generateTimeBasedUuid.getNode();
+ doh.assertTrue(returnedNode == "017bf397618a");
+
+ function getNode(string){
+ var arrayOfStrings = string.split('-');
+ return arrayOfStrings[4];
+ }
+ dojox.uuid.tests.uuid.checkForPseudoNodeBitInTimeBasedUuidString(string1);
+ dojox.uuid.tests.uuid.checkForPseudoNodeBitInTimeBasedUuidString(uuid2.toString());
+ dojox.uuid.tests.uuid.checkForPseudoNodeBitInTimeBasedUuidString(string4);
+
+ doh.assertTrue(getNode(string3) == "017bf397618a");
+ doh.assertTrue(getNode(string4) == "f17bf397618a");
+ doh.assertTrue(getNode(string5) == "017bf397618a");
+ doh.assertTrue(getNode(string6) == "017bf397618a");
+ doh.assertTrue(uuid7.getNode() == "017bf397618a");
+
+ dojox.uuid.tests.uuid.checkValidityOfTimeBasedUuidString(string1);
+ dojox.uuid.tests.uuid.checkValidityOfTimeBasedUuidString(uuid2.toString());
+ dojox.uuid.tests.uuid.checkValidityOfTimeBasedUuidString(string3);
+ dojox.uuid.tests.uuid.checkValidityOfTimeBasedUuidString(string4);
+ dojox.uuid.tests.uuid.checkValidityOfTimeBasedUuidString(string5);
+ dojox.uuid.tests.uuid.checkValidityOfTimeBasedUuidString(string6);
+ dojox.uuid.tests.uuid.checkValidityOfTimeBasedUuidString(uuid7.toString());
+ },
+
+ function test_uuid_invalidUuids(){
+ var uuidStrings = [];
+ uuidStrings.push("Hello world!"); // not a UUID
+ uuidStrings.push("3B12F1DF-5232-1804-897E-917BF39761"); // too short
+ uuidStrings.push("3B12F1DF-5232-1804-897E-917BF39761-8A"); // extra '-'
+ uuidStrings.push("3B12F1DF-5232-1804-897E917BF39761-8A"); // last '-' in wrong place
+ uuidStrings.push("HB12F1DF-5232-1804-897E-917BF397618A"); // "HB12F1DF" is not a hex string
+
+ var numberOfFailures = 0;
+ for(var i in uuidStrings){
+ var uuidString = uuidStrings[i];
+ try{
+ new dojox.uuid.Uuid(uuidString);
+ }catch (e){
+ ++numberOfFailures;
+ }
+ }
+ doh.assertTrue(numberOfFailures == uuidStrings.length);
+ }
+ ]
+);
+
+
+
+/*
+function test_uuid_get64bitArrayFromFloat(){
+ // summary:
+ // This is a test we'd like to be able to run, but we can't run it
+ // because it tests a function which is private in generateTimeBasedUuid
+ var x = Math.pow(2, 63) + Math.pow(2, 15);
+ var result = dojox.uuid.generateTimeBasedUuid._get64bitArrayFromFloat(x);
+ doh.assertTrue(result[0] === 0x8000);
+ doh.assertTrue(result[1] === 0x0000);
+ doh.assertTrue(result[2] === 0x0000);
+ doh.assertTrue(result[3] === 0x8000);
+
+ var date = new Date();
+ x = date.valueOf();
+ result = dojox.uuid.generateTimeBasedUuid._get64bitArrayFromFloat(x);
+ var reconstructedFloat = result[0];
+ reconstructedFloat *= 0x10000;
+ reconstructedFloat += result[1];
+ reconstructedFloat *= 0x10000;
+ reconstructedFloat += result[2];
+ reconstructedFloat *= 0x10000;
+ reconstructedFloat += result[3];
+
+ doh.assertTrue(reconstructedFloat === x);
+}
+
+function test_uuid_addTwo64bitArrays(){
+ // summary:
+ // This is a test we'd like to be able to run, but we can't run it
+ // because it tests a function which is private in generateTimeBasedUuid
+ var a = [0x0000, 0x0000, 0x0000, 0x0001];
+ var b = [0x0FFF, 0xFFFF, 0xFFFF, 0xFFFF];
+ var result = dojox.uuid.generateTimeBasedUuid._addTwo64bitArrays(a, b);
+ doh.assertTrue(result[0] === 0x1000);
+ doh.assertTrue(result[1] === 0x0000);
+ doh.assertTrue(result[2] === 0x0000);
+ doh.assertTrue(result[3] === 0x0000);
+
+ a = [0x4000, 0x8000, 0x8000, 0x8000];
+ b = [0x8000, 0x8000, 0x8000, 0x8000];
+ result = dojox.uuid.generateTimeBasedUuid._addTwo64bitArrays(a, b);
+ doh.assertTrue(result[0] === 0xC001);
+ doh.assertTrue(result[1] === 0x0001);
+ doh.assertTrue(result[2] === 0x0001);
+ doh.assertTrue(result[3] === 0x0000);
+
+ a = [7, 6, 2, 5];
+ b = [1, 0, 3, 4];
+ result = dojox.uuid.generateTimeBasedUuid._addTwo64bitArrays(a, b);
+ doh.assertTrue(result[0] === 8);
+ doh.assertTrue(result[1] === 6);
+ doh.assertTrue(result[2] === 5);
+ doh.assertTrue(result[3] === 9);
+}
+
+function test_uuid_multiplyTwo64bitArrays(){
+ // summary:
+ // This is a test we'd like to be able to run, but we can't run it
+ // because it tests a function which is private in generateTimeBasedUuid
+ var a = [ 0, 0x0000, 0x0000, 0x0003];
+ var b = [0x1111, 0x1234, 0x0000, 0xFFFF];
+ var result = dojox.uuid.generateTimeBasedUuid._multiplyTwo64bitArrays(a, b);
+ doh.assertTrue(result[0] === 0x3333);
+ doh.assertTrue(result[1] === 0x369C);
+ doh.assertTrue(result[2] === 0x0002);
+ doh.assertTrue(result[3] === 0xFFFD);
+
+ a = [0, 0, 0, 5];
+ b = [0, 0, 0, 4];
+ result = dojox.uuid.generateTimeBasedUuid._multiplyTwo64bitArrays(a, b);
+ doh.assertTrue(result[0] === 0);
+ doh.assertTrue(result[1] === 0);
+ doh.assertTrue(result[2] === 0);
+ doh.assertTrue(result[3] === 20);
+
+ a = [0, 0, 2, 5];
+ b = [0, 0, 3, 4];
+ result = dojox.uuid.generateTimeBasedUuid._multiplyTwo64bitArrays(a, b);
+ doh.assertTrue(result[0] === 0);
+ doh.assertTrue(result[1] === 6);
+ doh.assertTrue(result[2] === 23);
+ doh.assertTrue(result[3] === 20);
+}
+*/
+
+}