UNPKG

@dpkit/core

Version:

Fast TypeScript data management framework built on top of the Data Package standard and Polars DataFrames

103 lines 14.8 kB
import Slugger from "github-slugger"; import { node } from "./node.js"; export function isRemotePath(path) { try { new URL(path); return true; } catch { return false; } } export function getName(filename) { if (!filename) { return undefined; } const name = filename.split(".")[0]; if (!name) { return undefined; } const slugger = new Slugger(); return slugger.slug(name); } export function getFormat(filename) { return filename?.split(".").slice(-1)[0]?.toLowerCase(); } export function getFilename(path) { const isRemote = isRemotePath(path); if (isRemote) { const pathname = new URL(path).pathname; const filename = pathname.split("/").slice(-1)[0]; return filename?.includes(".") ? filename : undefined; } if (!node) { throw new Error("File system is not supported in this environment"); } const resolvedPath = node.path.resolve(path); const filename = node.path.parse(resolvedPath).base; return filename?.includes(".") ? filename : undefined; } export function getBasepath(path) { const isRemote = isRemotePath(path); if (isRemote) { const normalizedPath = new URL(path).toString(); return normalizedPath.split("/").slice(0, -1).join("/"); } if (!node) { throw new Error("File system is not supported in this environment"); } const resolvedPath = node.path.resolve(path); return node.path.relative(process.cwd(), node.path.parse(resolvedPath).dir); } export function normalizePath(path, options) { const isPathRemote = isRemotePath(path); const isBasepathRemote = isRemotePath(options.basepath ?? ""); if (isPathRemote) { return new URL(path).toString(); } if (isBasepathRemote) { const normalizedPath = new URL([options.basepath, path].join("/")).toString(); if (!normalizedPath.startsWith(options.basepath ?? "")) { throw new Error(`Path ${path} is not a subpath of ${options.basepath}`); } return normalizedPath; } if (!node) { throw new Error("File system is not supported in this environment"); } const normalizedPath = options.basepath ? node.path.join(options.basepath, path) : path; const relativePath = node.path.relative(options.basepath ?? "", normalizedPath); if (relativePath.startsWith("..")) { throw new Error(`Path ${path} is not a subpath of ${options.basepath}`); } return node.path.relative(process.cwd(), node.path.resolve(normalizedPath)); } export function denormalizePath(path, options) { const isPathRemote = isRemotePath(path); const isBasepathRemote = isRemotePath(options.basepath ?? ""); if (isPathRemote) { return new URL(path).toString(); } if (isBasepathRemote) { const basepath = new URL(options.basepath ?? "").toString(); if (!path.startsWith(basepath)) { throw new Error(`Path ${path} is not a subpath of ${options.basepath}`); } const relative = path.replace(`${basepath}/`, ""); return relative; } if (!node) { throw new Error("File system is not supported in this environment"); } const normalizedPath = node.path.resolve(path); const normalizedBasepath = node.path.resolve(options.basepath ?? ""); if (!normalizedPath.startsWith(normalizedBasepath)) { throw new Error(`Path ${path} is not a subpath of ${options.basepath}`); } // The Data Package standard requires "/" as the path separator const relative = node.path.relative(normalizedBasepath, normalizedPath); return relative.split(node.path.sep).join("/"); } //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"path.js","sourceRoot":"","sources":["../../general/path.ts"],"names":[],"mappings":"AAAA,OAAO,OAAO,MAAM,gBAAgB,CAAA;AACpC,OAAO,EAAE,IAAI,EAAE,MAAM,WAAW,CAAA;AAEhC,MAAM,UAAU,YAAY,CAAC,IAAY;IACvC,IAAI,CAAC;QACH,IAAI,GAAG,CAAC,IAAI,CAAC,CAAA;QACb,OAAO,IAAI,CAAA;IACb,CAAC;IAAC,MAAM,CAAC;QACP,OAAO,KAAK,CAAA;IACd,CAAC;AACH,CAAC;AAED,MAAM,UAAU,OAAO,CAAC,QAAiB;IACvC,IAAI,CAAC,QAAQ,EAAE,CAAC;QACd,OAAO,SAAS,CAAA;IAClB,CAAC;IAED,MAAM,IAAI,GAAG,QAAQ,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,CAAA;IACnC,IAAI,CAAC,IAAI,EAAE,CAAC;QACV,OAAO,SAAS,CAAA;IAClB,CAAC;IAED,MAAM,OAAO,GAAG,IAAI,OAAO,EAAE,CAAA;IAC7B,OAAO,OAAO,CAAC,IAAI,CAAC,IAAI,CAAC,CAAA;AAC3B,CAAC;AAED,MAAM,UAAU,SAAS,CAAC,QAAiB;IACzC,OAAO,QAAQ,EAAE,KAAK,CAAC,GAAG,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,EAAE,WAAW,EAAE,CAAA;AACzD,CAAC;AAED,MAAM,UAAU,WAAW,CAAC,IAAY;IACtC,MAAM,QAAQ,GAAG,YAAY,CAAC,IAAI,CAAC,CAAA;IAEnC,IAAI,QAAQ,EAAE,CAAC;QACb,MAAM,QAAQ,GAAG,IAAI,GAAG,CAAC,IAAI,CAAC,CAAC,QAAQ,CAAA;QACvC,MAAM,QAAQ,GAAG,QAAQ,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAA;QACjD,OAAO,QAAQ,EAAE,QAAQ,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAC,CAAC,SAAS,CAAA;IACvD,CAAC;IAED,IAAI,CAAC,IAAI,EAAE,CAAC;QACV,MAAM,IAAI,KAAK,CAAC,kDAAkD,CAAC,CAAA;IACrE,CAAC;IAED,MAAM,YAAY,GAAG,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,CAAA;IAC5C,MAAM,QAAQ,GAAG,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,YAAY,CAAC,CAAC,IAAI,CAAA;IACnD,OAAO,QAAQ,EAAE,QAAQ,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAC,CAAC,SAAS,CAAA;AACvD,CAAC;AAED,MAAM,UAAU,WAAW,CAAC,IAAY;IACtC,MAAM,QAAQ,GAAG,YAAY,CAAC,IAAI,CAAC,CAAA;IAEnC,IAAI,QAAQ,EAAE,CAAC;QACb,MAAM,cAAc,GAAG,IAAI,GAAG,CAAC,IAAI,CAAC,CAAC,QAAQ,EAAE,CAAA;QAC/C,OAAO,cAAc,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,KAAK,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,CAAA;IACzD,CAAC;IAED,IAAI,CAAC,IAAI,EAAE,CAAC;QACV,MAAM,IAAI,KAAK,CAAC,kDAAkD,CAAC,CAAA;IACrE,CAAC;IAED,MAAM,YAAY,GAAG,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,CAAA;IAC5C,OAAO,IAAI,CAAC,IAAI,CAAC,QAAQ,CAAC,OAAO,CAAC,GAAG,EAAE,EAAE,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,YAAY,CAAC,CAAC,GAAG,CAAC,CAAA;AAC7E,CAAC;AAED,MAAM,UAAU,aAAa,CAAC,IAAY,EAAE,OAA8B;IACxE,MAAM,YAAY,GAAG,YAAY,CAAC,IAAI,CAAC,CAAA;IACvC,MAAM,gBAAgB,GAAG,YAAY,CAAC,OAAO,CAAC,QAAQ,IAAI,EAAE,CAAC,CAAA;IAE7D,IAAI,YAAY,EAAE,CAAC;QACjB,OAAO,IAAI,GAAG,CAAC,IAAI,CAAC,CAAC,QAAQ,EAAE,CAAA;IACjC,CAAC;IAED,IAAI,gBAAgB,EAAE,CAAC;QACrB,MAAM,cAAc,GAAG,IAAI,GAAG,CAC5B,CAAC,OAAO,CAAC,QAAQ,EAAE,IAAI,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,CACnC,CAAC,QAAQ,EAAE,CAAA;QAEZ,IAAI,CAAC,cAAc,CAAC,UAAU,CAAC,OAAO,CAAC,QAAQ,IAAI,EAAE,CAAC,EAAE,CAAC;YACvD,MAAM,IAAI,KAAK,CAAC,QAAQ,IAAI,wBAAwB,OAAO,CAAC,QAAQ,EAAE,CAAC,CAAA;QACzE,CAAC;QAED,OAAO,cAAc,CAAA;IACvB,CAAC;IAED,IAAI,CAAC,IAAI,EAAE,CAAC;QACV,MAAM,IAAI,KAAK,CAAC,kDAAkD,CAAC,CAAA;IACrE,CAAC;IAED,MAAM,cAAc,GAAG,OAAO,CAAC,QAAQ;QACrC,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,QAAQ,EAAE,IAAI,CAAC;QACxC,CAAC,CAAC,IAAI,CAAA;IAER,MAAM,YAAY,GAAG,IAAI,CAAC,IAAI,CAAC,QAAQ,CACrC,OAAO,CAAC,QAAQ,IAAI,EAAE,EACtB,cAAc,CACf,CAAA;IACD,IAAI,YAAY,CAAC,UAAU,CAAC,IAAI,CAAC,EAAE,CAAC;QAClC,MAAM,IAAI,KAAK,CAAC,QAAQ,IAAI,wBAAwB,OAAO,CAAC,QAAQ,EAAE,CAAC,CAAA;IACzE,CAAC;IAED,OAAO,IAAI,CAAC,IAAI,CAAC,QAAQ,CAAC,OAAO,CAAC,GAAG,EAAE,EAAE,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,cAAc,CAAC,CAAC,CAAA;AAC7E,CAAC;AAED,MAAM,UAAU,eAAe,CAAC,IAAY,EAAE,OAA8B;IAC1E,MAAM,YAAY,GAAG,YAAY,CAAC,IAAI,CAAC,CAAA;IACvC,MAAM,gBAAgB,GAAG,YAAY,CAAC,OAAO,CAAC,QAAQ,IAAI,EAAE,CAAC,CAAA;IAE7D,IAAI,YAAY,EAAE,CAAC;QACjB,OAAO,IAAI,GAAG,CAAC,IAAI,CAAC,CAAC,QAAQ,EAAE,CAAA;IACjC,CAAC;IAED,IAAI,gBAAgB,EAAE,CAAC;QACrB,MAAM,QAAQ,GAAG,IAAI,GAAG,CAAC,OAAO,CAAC,QAAQ,IAAI,EAAE,CAAC,CAAC,QAAQ,EAAE,CAAA;QAE3D,IAAI,CAAC,IAAI,CAAC,UAAU,CAAC,QAAQ,CAAC,EAAE,CAAC;YAC/B,MAAM,IAAI,KAAK,CAAC,QAAQ,IAAI,wBAAwB,OAAO,CAAC,QAAQ,EAAE,CAAC,CAAA;QACzE,CAAC;QAED,MAAM,QAAQ,GAAG,IAAI,CAAC,OAAO,CAAC,GAAG,QAAQ,GAAG,EAAE,EAAE,CAAC,CAAA;QACjD,OAAO,QAAQ,CAAA;IACjB,CAAC;IAED,IAAI,CAAC,IAAI,EAAE,CAAC;QACV,MAAM,IAAI,KAAK,CAAC,kDAAkD,CAAC,CAAA;IACrE,CAAC;IAED,MAAM,cAAc,GAAG,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,CAAA;IAC9C,MAAM,kBAAkB,GAAG,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,OAAO,CAAC,QAAQ,IAAI,EAAE,CAAC,CAAA;IAEpE,IAAI,CAAC,cAAc,CAAC,UAAU,CAAC,kBAAkB,CAAC,EAAE,CAAC;QACnD,MAAM,IAAI,KAAK,CAAC,QAAQ,IAAI,wBAAwB,OAAO,CAAC,QAAQ,EAAE,CAAC,CAAA;IACzE,CAAC;IAED,+DAA+D;IAC/D,MAAM,QAAQ,GAAG,IAAI,CAAC,IAAI,CAAC,QAAQ,CAAC,kBAAkB,EAAE,cAAc,CAAC,CAAA;IACvE,OAAO,QAAQ,CAAC,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,CAAA;AAChD,CAAC","sourcesContent":["import Slugger from \"github-slugger\"\nimport { node } from \"./node.js\"\n\nexport function isRemotePath(path: string) {\n  try {\n    new URL(path)\n    return true\n  } catch {\n    return false\n  }\n}\n\nexport function getName(filename?: string) {\n  if (!filename) {\n    return undefined\n  }\n\n  const name = filename.split(\".\")[0]\n  if (!name) {\n    return undefined\n  }\n\n  const slugger = new Slugger()\n  return slugger.slug(name)\n}\n\nexport function getFormat(filename?: string) {\n  return filename?.split(\".\").slice(-1)[0]?.toLowerCase()\n}\n\nexport function getFilename(path: string) {\n  const isRemote = isRemotePath(path)\n\n  if (isRemote) {\n    const pathname = new URL(path).pathname\n    const filename = pathname.split(\"/\").slice(-1)[0]\n    return filename?.includes(\".\") ? filename : undefined\n  }\n\n  if (!node) {\n    throw new Error(\"File system is not supported in this environment\")\n  }\n\n  const resolvedPath = node.path.resolve(path)\n  const filename = node.path.parse(resolvedPath).base\n  return filename?.includes(\".\") ? filename : undefined\n}\n\nexport function getBasepath(path: string) {\n  const isRemote = isRemotePath(path)\n\n  if (isRemote) {\n    const normalizedPath = new URL(path).toString()\n    return normalizedPath.split(\"/\").slice(0, -1).join(\"/\")\n  }\n\n  if (!node) {\n    throw new Error(\"File system is not supported in this environment\")\n  }\n\n  const resolvedPath = node.path.resolve(path)\n  return node.path.relative(process.cwd(), node.path.parse(resolvedPath).dir)\n}\n\nexport function normalizePath(path: string, options: { basepath?: string }) {\n  const isPathRemote = isRemotePath(path)\n  const isBasepathRemote = isRemotePath(options.basepath ?? \"\")\n\n  if (isPathRemote) {\n    return new URL(path).toString()\n  }\n\n  if (isBasepathRemote) {\n    const normalizedPath = new URL(\n      [options.basepath, path].join(\"/\"),\n    ).toString()\n\n    if (!normalizedPath.startsWith(options.basepath ?? \"\")) {\n      throw new Error(`Path ${path} is not a subpath of ${options.basepath}`)\n    }\n\n    return normalizedPath\n  }\n\n  if (!node) {\n    throw new Error(\"File system is not supported in this environment\")\n  }\n\n  const normalizedPath = options.basepath\n    ? node.path.join(options.basepath, path)\n    : path\n\n  const relativePath = node.path.relative(\n    options.basepath ?? \"\",\n    normalizedPath,\n  )\n  if (relativePath.startsWith(\"..\")) {\n    throw new Error(`Path ${path} is not a subpath of ${options.basepath}`)\n  }\n\n  return node.path.relative(process.cwd(), node.path.resolve(normalizedPath))\n}\n\nexport function denormalizePath(path: string, options: { basepath?: string }) {\n  const isPathRemote = isRemotePath(path)\n  const isBasepathRemote = isRemotePath(options.basepath ?? \"\")\n\n  if (isPathRemote) {\n    return new URL(path).toString()\n  }\n\n  if (isBasepathRemote) {\n    const basepath = new URL(options.basepath ?? \"\").toString()\n\n    if (!path.startsWith(basepath)) {\n      throw new Error(`Path ${path} is not a subpath of ${options.basepath}`)\n    }\n\n    const relative = path.replace(`${basepath}/`, \"\")\n    return relative\n  }\n\n  if (!node) {\n    throw new Error(\"File system is not supported in this environment\")\n  }\n\n  const normalizedPath = node.path.resolve(path)\n  const normalizedBasepath = node.path.resolve(options.basepath ?? \"\")\n\n  if (!normalizedPath.startsWith(normalizedBasepath)) {\n    throw new Error(`Path ${path} is not a subpath of ${options.basepath}`)\n  }\n\n  // The Data Package standard requires \"/\" as the path separator\n  const relative = node.path.relative(normalizedBasepath, normalizedPath)\n  return relative.split(node.path.sep).join(\"/\")\n}\n"]}