diff options
Diffstat (limited to 'includes/js/dojox/uuid')
| -rw-r--r-- | includes/js/dojox/uuid/README | 43 | ||||
| -rw-r--r-- | includes/js/dojox/uuid/Uuid.js | 200 | ||||
| -rw-r--r-- | includes/js/dojox/uuid/_base.js | 245 | ||||
| -rw-r--r-- | includes/js/dojox/uuid/generateRandomUuid.js | 56 | ||||
| -rw-r--r-- | includes/js/dojox/uuid/generateTimeBasedUuid.js | 290 | ||||
| -rw-r--r-- | includes/js/dojox/uuid/tests/runTests.html | 10 | ||||
| -rw-r--r-- | includes/js/dojox/uuid/tests/uuid.js | 377 | 
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); +} +*/ + +} | 
