From 76cb9c2a39d477a64824a985ade40507e3bbade1 Mon Sep 17 00:00:00 2001 From: Adam Mathes Date: Fri, 13 Feb 2026 21:34:48 -0800 Subject: feat(vanilla): add testing infrastructure and tests (NK-wjnczv) --- vanilla/node_modules/tldts/index.ts | 62 +++++++++++++++++++++++++++++++++++++ 1 file changed, 62 insertions(+) create mode 100644 vanilla/node_modules/tldts/index.ts (limited to 'vanilla/node_modules/tldts/index.ts') diff --git a/vanilla/node_modules/tldts/index.ts b/vanilla/node_modules/tldts/index.ts new file mode 100644 index 0000000..f9865cd --- /dev/null +++ b/vanilla/node_modules/tldts/index.ts @@ -0,0 +1,62 @@ +import { + FLAG, + getEmptyResult, + IOptions, + IResult, + parseImpl, + resetResult, +} from 'tldts-core'; + +import suffixLookup from './src/suffix-trie'; + +// For all methods but 'parse', it does not make sense to allocate an object +// every single time to only return the value of a specific attribute. To avoid +// this un-necessary allocation, we use a global object which is re-used. +const RESULT: IResult = getEmptyResult(); + +export function parse(url: string, options: Partial = {}): IResult { + return parseImpl(url, FLAG.ALL, suffixLookup, options, getEmptyResult()); +} + +export function getHostname( + url: string, + options: Partial = {}, +): string | null { + /*@__INLINE__*/ resetResult(RESULT); + return parseImpl(url, FLAG.HOSTNAME, suffixLookup, options, RESULT).hostname; +} + +export function getPublicSuffix( + url: string, + options: Partial = {}, +): string | null { + /*@__INLINE__*/ resetResult(RESULT); + return parseImpl(url, FLAG.PUBLIC_SUFFIX, suffixLookup, options, RESULT) + .publicSuffix; +} + +export function getDomain( + url: string, + options: Partial = {}, +): string | null { + /*@__INLINE__*/ resetResult(RESULT); + return parseImpl(url, FLAG.DOMAIN, suffixLookup, options, RESULT).domain; +} + +export function getSubdomain( + url: string, + options: Partial = {}, +): string | null { + /*@__INLINE__*/ resetResult(RESULT); + return parseImpl(url, FLAG.SUB_DOMAIN, suffixLookup, options, RESULT) + .subdomain; +} + +export function getDomainWithoutSuffix( + url: string, + options: Partial = {}, +): string | null { + /*@__INLINE__*/ resetResult(RESULT); + return parseImpl(url, FLAG.ALL, suffixLookup, options, RESULT) + .domainWithoutSuffix; +} -- cgit v1.2.3