You can not select more than 25 topics
			Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
		
		
		
		
		
			
		
			
				
					
					
						
							109 lines
						
					
					
						
							2.3 KiB
						
					
					
				
			
		
		
	
	
							109 lines
						
					
					
						
							2.3 KiB
						
					
					
				| /**
 | |
|  * Mnemonist DefaultWeakMap
 | |
|  * =========================
 | |
|  *
 | |
|  * JavaScript implementation of a default weak map that will return a constructed
 | |
|  * value any time one tries to access an non-existing key. It is similar to
 | |
|  * DefaultMap but uses ES6 WeakMap that only holds weak reference to keys.
 | |
|  */
 | |
| 
 | |
| /**
 | |
|  * DefaultWeakMap.
 | |
|  *
 | |
|  * @constructor
 | |
|  */
 | |
| function DefaultWeakMap(factory) {
 | |
|   if (typeof factory !== 'function')
 | |
|     throw new Error('mnemonist/DefaultWeakMap.constructor: expecting a function.');
 | |
| 
 | |
|   this.items = new WeakMap();
 | |
|   this.factory = factory;
 | |
| }
 | |
| 
 | |
| /**
 | |
|  * Method used to clear the structure.
 | |
|  *
 | |
|  * @return {undefined}
 | |
|  */
 | |
| DefaultWeakMap.prototype.clear = function() {
 | |
| 
 | |
|   // Properties
 | |
|   this.items = new WeakMap();
 | |
| };
 | |
| 
 | |
| /**
 | |
|  * Method used to get the value set for given key. If the key does not exist,
 | |
|  * the value will be created using the provided factory.
 | |
|  *
 | |
|  * @param  {any} key - Target key.
 | |
|  * @return {any}
 | |
|  */
 | |
| DefaultWeakMap.prototype.get = function(key) {
 | |
|   var value = this.items.get(key);
 | |
| 
 | |
|   if (typeof value === 'undefined') {
 | |
|     value = this.factory(key);
 | |
|     this.items.set(key, value);
 | |
|   }
 | |
| 
 | |
|   return value;
 | |
| };
 | |
| 
 | |
| /**
 | |
|  * Method used to get the value set for given key. If the key does not exist,
 | |
|  * a value won't be created.
 | |
|  *
 | |
|  * @param  {any} key - Target key.
 | |
|  * @return {any}
 | |
|  */
 | |
| DefaultWeakMap.prototype.peek = function(key) {
 | |
|   return this.items.get(key);
 | |
| };
 | |
| 
 | |
| /**
 | |
|  * Method used to set a value for given key.
 | |
|  *
 | |
|  * @param  {any} key   - Target key.
 | |
|  * @param  {any} value - Value.
 | |
|  * @return {DefaultMap}
 | |
|  */
 | |
| DefaultWeakMap.prototype.set = function(key, value) {
 | |
|   this.items.set(key, value);
 | |
|   return this;
 | |
| };
 | |
| 
 | |
| /**
 | |
|  * Method used to test the existence of a key in the map.
 | |
|  *
 | |
|  * @param  {any} key   - Target key.
 | |
|  * @return {boolean}
 | |
|  */
 | |
| DefaultWeakMap.prototype.has = function(key) {
 | |
|   return this.items.has(key);
 | |
| };
 | |
| 
 | |
| /**
 | |
|  * Method used to delete target key.
 | |
|  *
 | |
|  * @param  {any} key   - Target key.
 | |
|  * @return {boolean}
 | |
|  */
 | |
| DefaultWeakMap.prototype.delete = function(key) {
 | |
|   return this.items.delete(key);
 | |
| };
 | |
| 
 | |
| /**
 | |
|  * Convenience known methods.
 | |
|  */
 | |
| DefaultWeakMap.prototype.inspect = function() {
 | |
|   return this.items;
 | |
| };
 | |
| 
 | |
| if (typeof Symbol !== 'undefined')
 | |
|   DefaultWeakMap.prototype[Symbol.for('nodejs.util.inspect.custom')] = DefaultWeakMap.prototype.inspect;
 | |
| 
 | |
| /**
 | |
|  * Exporting.
 | |
|  */
 | |
| module.exports = DefaultWeakMap;
 |