mirror of
https://github.com/Instadapp/trustwallet-assets.git
synced 2024-07-29 22:37:31 +00:00
102f2b88d4
* CMC mapping update. * New check infrastructure, move root folder test to new infra. * Move list of allowed files to config. * Include new check in other tests. * More generic way to call checks. * Organize fix and update actions behind interfaces. * Organize checks into steps, multiple steps per action. * Simplify checkStep class/instance creation. * Migrate chain logo checks. * Migrate asset folder check. * Migrate further chain checks. * Migrate eth fork folder checks. * Migrate binance chain check. * Extra output. * Output improvements. * Async fix. * Migrate Tron check. * Add Tron check. * Remove Tron check from old. * White/blacklist check in new intra, combined with fix. * Refine ETH checks. * Remove from old infra. * Migrate CMC check to new infra. * Migrate validator tests to new check infra. * Migrate Json files validity check to new check infra. * Whitelist check fix. * Cleanup helpers.ts. * Move helpers.ts. * Cleanup of models.ts. * Move models.ts. * Move index.test.ts. * Update with BEP8 support. * Descriptive names for jobs within the builds. Co-authored-by: Catenocrypt <catenocrypt@users.noreply.github.com>
52 lines
1.6 KiB
TypeScript
52 lines
1.6 KiB
TypeScript
export const isLowerCase = (str: string): boolean => str.toLowerCase() === str;
|
|
export const isUpperCase = (str: string): boolean => str.toUpperCase() === str;
|
|
|
|
export const mapList = arr => {
|
|
return arr.reduce((acm, val) => {
|
|
acm[val] = "";
|
|
return acm;
|
|
}, {});
|
|
}
|
|
|
|
// Sort: treat numbers as number, strings as case-insensitive
|
|
export const sortElements = (arr: any[]): any[] => {
|
|
arr.sort((a, b) => {
|
|
if (!isNaN(a) && !isNaN(b)) {
|
|
// numerical comparison
|
|
return a - b;
|
|
}
|
|
if ((typeof a === 'string' || a instanceof String) && (typeof b === 'string' || b instanceof String)) {
|
|
return a.toLowerCase() > b.toLowerCase() ? 1 : -1;
|
|
}
|
|
return 0;
|
|
});
|
|
return arr;
|
|
}
|
|
|
|
export const makeUnique = (arr: any[]): any[] => Array.from(new Set(arr));
|
|
|
|
// Remove from set a elements of set b.
|
|
export function arrayDiff(a: string[], b: string[]): string[] {
|
|
const mappedB = mapList(b);
|
|
return a.filter(e => !mappedB.hasOwnProperty(e));
|
|
}
|
|
|
|
export function findDuplicate(list: string[]): string {
|
|
let m = new Map<string, number>();
|
|
let duplicate: string = null;
|
|
list.forEach(val => {
|
|
if (m.has(val)) {
|
|
duplicate = val;
|
|
} else {
|
|
m.set(val, 0);
|
|
}
|
|
});
|
|
return duplicate;
|
|
}
|
|
|
|
// Check that two lists have no common elements, and no duplicates in either.
|
|
// Do a single check: checking for duplicates in the concatenated list.
|
|
export function findCommonElementOrDuplicate(list1: string[], list2: string[]) {
|
|
return findDuplicate(list1.concat(list2));
|
|
}
|