58 lines
		
	
	
		
			2.0 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
			
		
		
	
	
			58 lines
		
	
	
		
			2.0 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
| "use strict";
 | |
| /*
 | |
|  * Copyright 2024 Google LLC.
 | |
|  * Copyright (c) Microsoft Corporation.
 | |
|  *
 | |
|  * Licensed under the Apache License, Version 2.0 (the "License");
 | |
|  * you may not use this file except in compliance with the License.
 | |
|  * You may obtain a copy of the License at
 | |
|  *
 | |
|  *     http://www.apache.org/licenses/LICENSE-2.0
 | |
|  *
 | |
|  * Unless required by applicable law or agreed to in writing, software
 | |
|  * distributed under the License is distributed on an "AS IS" BASIS,
 | |
|  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 | |
|  * See the License for the specific language governing permissions and
 | |
|  * limitations under the License.
 | |
|  */
 | |
| Object.defineProperty(exports, "__esModule", { value: true });
 | |
| exports.distinctValues = distinctValues;
 | |
| exports.deterministicJSONStringify = deterministicJSONStringify;
 | |
| /**
 | |
|  * Returns an array of distinct values. Order is not guaranteed.
 | |
|  * @param values - The values to filter. Should be JSON-serializable.
 | |
|  * @return - An array of distinct values.
 | |
|  */
 | |
| function distinctValues(values) {
 | |
|     const map = new Map();
 | |
|     for (const value of values) {
 | |
|         map.set(deterministicJSONStringify(value), value);
 | |
|     }
 | |
|     return Array.from(map.values());
 | |
| }
 | |
| /**
 | |
|  * Returns a stringified version of the object with keys sorted. This is required to
 | |
|  * ensure that the stringified version of an object is deterministic independent of the
 | |
|  * order of keys.
 | |
|  * @param obj
 | |
|  * @return {string}
 | |
|  */
 | |
| function deterministicJSONStringify(obj) {
 | |
|     return JSON.stringify(normalizeObject(obj));
 | |
| }
 | |
| function normalizeObject(obj) {
 | |
|     if (obj === undefined ||
 | |
|         obj === null ||
 | |
|         Array.isArray(obj) ||
 | |
|         typeof obj !== 'object') {
 | |
|         return obj;
 | |
|     }
 | |
|     // Copy the original object key and values to a new object in sorted order.
 | |
|     const newObj = {};
 | |
|     for (const key of Object.keys(obj).sort()) {
 | |
|         const value = obj[key];
 | |
|         newObj[key] = normalizeObject(value); // Recursively sort nested objects
 | |
|     }
 | |
|     return newObj;
 | |
| }
 | |
| //# sourceMappingURL=DistinctValues.js.map
 |