aboutsummaryrefslogtreecommitdiffstats
path: root/vanilla/node_modules/tldts/index.ts
diff options
context:
space:
mode:
authorAdam Mathes <adam@adammathes.com>2026-02-13 21:34:48 -0800
committerAdam Mathes <adam@adammathes.com>2026-02-13 21:34:48 -0800
commit76cb9c2a39d477a64824a985ade40507e3bbade1 (patch)
tree41e997aa9c6f538d3a136af61dae9424db2005a9 /vanilla/node_modules/tldts/index.ts
parent819a39a21ac992b1393244a4c283bbb125208c69 (diff)
downloadneko-76cb9c2a39d477a64824a985ade40507e3bbade1.tar.gz
neko-76cb9c2a39d477a64824a985ade40507e3bbade1.tar.bz2
neko-76cb9c2a39d477a64824a985ade40507e3bbade1.zip
feat(vanilla): add testing infrastructure and tests (NK-wjnczv)
Diffstat (limited to 'vanilla/node_modules/tldts/index.ts')
-rw-r--r--vanilla/node_modules/tldts/index.ts62
1 files changed, 62 insertions, 0 deletions
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<IOptions> = {}): IResult {
+ return parseImpl(url, FLAG.ALL, suffixLookup, options, getEmptyResult());
+}
+
+export function getHostname(
+ url: string,
+ options: Partial<IOptions> = {},
+): string | null {
+ /*@__INLINE__*/ resetResult(RESULT);
+ return parseImpl(url, FLAG.HOSTNAME, suffixLookup, options, RESULT).hostname;
+}
+
+export function getPublicSuffix(
+ url: string,
+ options: Partial<IOptions> = {},
+): string | null {
+ /*@__INLINE__*/ resetResult(RESULT);
+ return parseImpl(url, FLAG.PUBLIC_SUFFIX, suffixLookup, options, RESULT)
+ .publicSuffix;
+}
+
+export function getDomain(
+ url: string,
+ options: Partial<IOptions> = {},
+): string | null {
+ /*@__INLINE__*/ resetResult(RESULT);
+ return parseImpl(url, FLAG.DOMAIN, suffixLookup, options, RESULT).domain;
+}
+
+export function getSubdomain(
+ url: string,
+ options: Partial<IOptions> = {},
+): string | null {
+ /*@__INLINE__*/ resetResult(RESULT);
+ return parseImpl(url, FLAG.SUB_DOMAIN, suffixLookup, options, RESULT)
+ .subdomain;
+}
+
+export function getDomainWithoutSuffix(
+ url: string,
+ options: Partial<IOptions> = {},
+): string | null {
+ /*@__INLINE__*/ resetResult(RESULT);
+ return parseImpl(url, FLAG.ALL, suffixLookup, options, RESULT)
+ .domainWithoutSuffix;
+}