From 99bbf1fd3206680e78ace758933785f38bb72c27 Mon Sep 17 00:00:00 2001 From: Eliott C Date: Tue, 7 May 2024 14:37:50 +0200 Subject: [PATCH] =?UTF-8?q?=E2=99=BB=EF=B8=8F=20Make=20"go=20to=20source?= =?UTF-8?q?=20definition"=20work=20(#658)?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Sorry for all the codeowners reviews Make "go to source definition" work by using the package, thanks to `.d.ts.map` files generated by `tsc`. Defer type generation to `tsc` instead of `tsup`, since `tsup` is not able to generate `.d.ts.map`. Also removed `shared` package - since we don't want to publish it, having "go to source" with it would have been problematic. Instead, "shared" files are duplicated between `@huggingface/inference` and `@huggingface/hub`. Maybe later we can create `@huggingface/webblob` and `@huggingface/fileblob` if we want to reuse them. See also: https://www.npmjs.com/package/dts-buddy used by svelte-kit --- .github/workflows/hub-publish.yml | 38 ++++++++++ .github/workflows/test.yml | 50 ++++++++++++- e2e/.gitignore | 2 + package.json | 2 + packages/agents/package.json | 5 +- packages/agents/pnpm-lock.yaml | 8 --- packages/agents/tsconfig.json | 5 +- packages/agents/tsup.config.ts | 3 - packages/gguf/.eslintignore | 1 + packages/gguf/package.json | 7 +- packages/gguf/pnpm-lock.yaml | 12 ---- packages/gguf/tsconfig.json | 4 +- packages/gguf/tsup.config.ts | 3 - packages/hub/README.md | 2 +- packages/hub/package.json | 7 +- packages/hub/pnpm-lock.yaml | 14 +--- packages/hub/src/error.ts | 2 +- packages/hub/src/lib/commit.spec.ts | 2 +- packages/hub/src/lib/commit.ts | 3 +- packages/hub/src/lib/create-repo.ts | 2 +- packages/hub/src/lib/oauth-login-url.ts | 2 +- .../hub/src/lib/parse-safetensors-metadata.ts | 2 +- .../api/{api-commit.d.ts => api-commit.ts} | 2 +- ...pi-create-repo.d.ts => api-create-repo.ts} | 4 +- .../api/{api-dataset.d.ts => api-dataset.ts} | 0 ...{api-index-tree.d.ts => api-index-tree.ts} | 4 +- .../api/{api-model.d.ts => api-model.ts} | 0 .../api/{api-space.d.ts => api-space.ts} | 0 .../{api-who-am-i.d.ts => api-who-am-i.ts} | 0 .../hub/src/types/{public.d.ts => public.ts} | 0 packages/hub/src/utils/WebBlob.spec.ts | 2 +- .../src => hub/src/utils}/base64FromBytes.ts | 0 packages/hub/src/utils/createBlob.ts | 2 +- .../src => hub/src/utils}/isBackend.ts | 0 .../src => hub/src/utils}/isFrontend.ts | 0 packages/hub/src/utils/sha256.ts | 2 +- packages/hub/src/utils/typedEntries.ts | 2 +- packages/hub/src/vendor/type-fest/basic.ts | 31 ++++++++ packages/hub/src/vendor/type-fest/entries.ts | 65 +++++++++++++++++ packages/hub/src/vendor/type-fest/entry.ts | 68 ++++++++++++++++++ packages/hub/src/vendor/type-fest/except.ts | 71 +++++++++++++++++++ packages/hub/src/vendor/type-fest/is-equal.ts | 27 +++++++ .../hub/src/vendor/type-fest/set-required.ts | 34 +++++++++ packages/hub/src/vendor/type-fest/simplify.ts | 59 +++++++++++++++ packages/hub/tsconfig.json | 6 +- packages/hub/tsup.config.ts | 3 - packages/inference/README.md | 4 ++ packages/inference/package.json | 6 +- .../inference/src/tasks/cv/imageToImage.ts | 2 +- .../tasks/cv/zeroShotImageClassification.ts | 2 +- .../multimodal/documentQuestionAnswering.ts | 2 +- .../multimodal/visualQuestionAnswering.ts | 2 +- .../inference/src/utils/base64FromBytes.ts | 11 +++ ...ibutive-omit.d.ts => distributive-omit.ts} | 2 - packages/inference/src/utils/isBackend.ts | 6 ++ packages/inference/src/utils/isFrontend.ts | 3 + packages/inference/test/vcr.ts | 3 +- packages/inference/tsconfig.json | 8 ++- packages/jinja/package.json | 2 +- packages/jinja/tsconfig.json | 3 +- packages/languages/package.json | 2 +- packages/languages/tsconfig.json | 4 +- packages/shared/package.json | 8 --- packages/shared/pnpm-lock.yaml | 5 -- packages/shared/src/index.ts | 3 - packages/shared/tsconfig.json | 14 ---- packages/tasks/package.json | 8 +-- packages/tasks/tsconfig.json | 4 +- packages/widgets/tsconfig.json | 4 +- packages/widgets/vite.config.ts | 1 + pnpm-workspace.yaml | 1 - 71 files changed, 537 insertions(+), 131 deletions(-) create mode 100644 e2e/.gitignore create mode 100644 packages/gguf/.eslintignore rename packages/hub/src/types/api/{api-commit.d.ts => api-commit.ts} (99%) rename packages/hub/src/types/api/{api-create-repo.d.ts => api-create-repo.ts} (76%) rename packages/hub/src/types/api/{api-dataset.d.ts => api-dataset.ts} (100%) rename packages/hub/src/types/api/{api-index-tree.d.ts => api-index-tree.ts} (92%) rename packages/hub/src/types/api/{api-model.d.ts => api-model.ts} (100%) rename packages/hub/src/types/api/{api-space.d.ts => api-space.ts} (100%) rename packages/hub/src/types/api/{api-who-am-i.d.ts => api-who-am-i.ts} (100%) rename packages/hub/src/types/{public.d.ts => public.ts} (100%) rename packages/{shared/src => hub/src/utils}/base64FromBytes.ts (100%) rename packages/{shared/src => hub/src/utils}/isBackend.ts (100%) rename packages/{shared/src => hub/src/utils}/isFrontend.ts (100%) create mode 100644 packages/hub/src/vendor/type-fest/basic.ts create mode 100644 packages/hub/src/vendor/type-fest/entries.ts create mode 100644 packages/hub/src/vendor/type-fest/entry.ts create mode 100644 packages/hub/src/vendor/type-fest/except.ts create mode 100644 packages/hub/src/vendor/type-fest/is-equal.ts create mode 100644 packages/hub/src/vendor/type-fest/set-required.ts create mode 100644 packages/hub/src/vendor/type-fest/simplify.ts create mode 100644 packages/inference/src/utils/base64FromBytes.ts rename packages/inference/src/utils/{distributive-omit.d.ts => distributive-omit.ts} (84%) create mode 100644 packages/inference/src/utils/isBackend.ts create mode 100644 packages/inference/src/utils/isFrontend.ts delete mode 100644 packages/shared/package.json delete mode 100644 packages/shared/pnpm-lock.yaml delete mode 100644 packages/shared/src/index.ts delete mode 100644 packages/shared/tsconfig.json diff --git a/.github/workflows/hub-publish.yml b/.github/workflows/hub-publish.yml index 4a75fe7af..19bb63dcf 100644 --- a/.github/workflows/hub-publish.yml +++ b/.github/workflows/hub-publish.yml @@ -52,6 +52,44 @@ jobs: git add ../.. git commit -m "🔖 @hugginface/hub $BUMPED_VERSION" git tag "hub-v$BUMPED_VERSION" + + - name: Make sure that the latest version of @huggingface/tasks is consistent with the local version + run: | + LOCAL_TASKS_VERSION=$(node -p "require('./package.json').version") + REMOTE_TASKS_VERSION=$(npm view @huggingface/tasks version) + + # If the versions are different, error + if [ "$LOCAL_TASKS_VERSION" != "$REMOTE_TASKS_VERSION" ]; then + echo "Error: The local @huggingface/tasks package version ($LOCAL_TASKS_VERSION) differs from the remote version ($REMOTE_TASKS_VERSION). Release halted." + exit 1 + fi + + npm pack @huggingface/tasks + mv huggingface-tasks-$LOCAL_TASKS_VERSION.tgz tasks-local.tgz + + npm pack @huggingface/tasks@$REMOTE_TASKS_VERSION + mv huggingface-tasks-$REMOTE_TASKS_VERSION.tgz tasks-remote.tgz + + # Compute checksum of local tar. We need to extract both tar since the remote compression might be different + tar -xf tasks-local.tgz + LOCAL_CHECKSUM=$(cd package && tar --mtime='1970-01-01' --mode=755 -cf - . | sha256sum | cut -d' ' -f1) + echo "Local package checksum: $LOCAL_CHECKSUM" + + rm -Rf package + + tar -xf tasks-remote.tgz + REMOTE_CHECKSUM=$(cd package && tar --mtime='1970-01-01' --mode=755 -cf - . | sha256sum | cut -d' ' -f1) + echo "Remote package checksum: $REMOTE_CHECKSUM" + + rm -Rf package + + if [ "$LOCAL_CHECKSUM" != "$REMOTE_CHECKSUM" ]; then + echo "Checksum Verification Failed: The local @huggingface/tasks package differs from the remote version. Release halted. Local Checksum: $LOCAL_CHECKSUM, Remote Checksum: $REMOTE_CHECKSUM" + exit 1 + fi + echo "Checksum Verification Successful: The local and remote @huggingface/tasks packages are consistent. Proceeding with the @huggingface/widgets package release. Local Checksum: $LOCAL_CHECKSUM, Remote Checksum: $REMOTE_CHECKSUM." + working-directory: packages/tasks + - run: pnpm publish --no-git-checks . env: NODE_AUTH_TOKEN: ${{ secrets.NPM_TOKEN }} diff --git a/.github/workflows/test.yml b/.github/workflows/test.yml index 99df0df10..f2f7f0ec5 100644 --- a/.github/workflows/test.yml +++ b/.github/workflows/test.yml @@ -6,7 +6,7 @@ on: - main jobs: - test: + node: runs-on: ubuntu-latest timeout-minutes: 10 @@ -42,11 +42,57 @@ jobs: env: HF_TOKEN: ${{ secrets.HF_TOKEN }} + browser: + runs-on: ubuntu-latest + timeout-minutes: 10 + + steps: + - uses: actions/checkout@v3 + with: + # Could use something like rmacklin/fetch-through-merge-base@v0 instead when the repo gets bigger + fetch-depth: 0 + - name: "Extracting the merge base into 'SINCE'" + id: since + run: | + if [ -z "${{ github.event.pull_request.head.ref }}" ] + then + echo "SINCE=${{ github.sha }}^1" >> $GITHUB_OUTPUT + else + echo "SINCE=$(git merge-base origin/${{ github.event.pull_request.base.ref }} ${{ github.sha }})" >> $GITHUB_OUTPUT + fi + + - run: corepack enable + + - uses: actions/setup-node@v3 + with: + node-version: "20" + cache: "pnpm" + cache-dependency-path: "**/pnpm-lock.yaml" + - run: | + pnpm install --frozen-lockfile --filter . + pnpm install --frozen-lockfile --filter ...[${{ steps.since.outputs.SINCE }}]... + pnpm --filter ...[${{ steps.since.outputs.SINCE }}]... build + - name: Test in browser run: VCR_MODE=playback pnpm --filter ...[${{ steps.since.outputs.SINCE }}] test:browser env: HF_TOKEN: ${{ secrets.HF_TOKEN }} + e2e: + runs-on: ubuntu-latest + timeout-minutes: 10 + + steps: + - uses: actions/checkout@v3 + + - run: corepack enable + + - uses: actions/setup-node@v3 + with: + node-version: "20" + cache: "pnpm" + cache-dependency-path: "**/pnpm-lock.yaml" + - name: E2E - start mock npm registry run: | npm i -g verdaccio verdaccio-memory verdaccio-auth-memory @@ -58,7 +104,7 @@ jobs: working-directory: e2e run: | sleep 3 - pnpm i --filter inference... --filter hub... --frozen-lockfile + pnpm i --filter root --filter inference... --filter hub... --frozen-lockfile pnpm --filter inference --filter hub --filter tasks publish --force --no-git-checks --registry http://localhost:4874/ - name: E2E test - test yarn install diff --git a/e2e/.gitignore b/e2e/.gitignore new file mode 100644 index 000000000..cc850e813 --- /dev/null +++ b/e2e/.gitignore @@ -0,0 +1,2 @@ +# Modified during E2E tests +.npmrc \ No newline at end of file diff --git a/package.json b/package.json index 3557bab70..4a673528a 100644 --- a/package.json +++ b/package.json @@ -1,4 +1,6 @@ { + "private": true, + "name": "@huggingface/root", "license": "MIT", "packageManager": "pnpm@8.10.5", "scripts": { diff --git a/packages/agents/package.json b/packages/agents/package.json index 4a887c745..d9c57eace 100644 --- a/packages/agents/package.json +++ b/packages/agents/package.json @@ -31,7 +31,7 @@ "format": "prettier --write .", "format:check": "prettier --check .", "prepublishOnly": "pnpm run build", - "build": "tsup", + "build": "tsup && tsc --emitDeclarationOnly --declaration", "test": "vitest run", "test:browser": "vitest run --browser.name=chrome --browser.headless --config vitest-browser.config.mts", "check": "tsc" @@ -53,8 +53,7 @@ "author": "Hugging Face", "license": "MIT", "devDependencies": { - "@types/node": "^18.13.0", - "type-fest": "^3.9.0" + "@types/node": "^18.13.0" }, "dependencies": { "@huggingface/inference": "^2.6.1" diff --git a/packages/agents/pnpm-lock.yaml b/packages/agents/pnpm-lock.yaml index 3b91f9cee..060aacb35 100644 --- a/packages/agents/pnpm-lock.yaml +++ b/packages/agents/pnpm-lock.yaml @@ -13,17 +13,9 @@ devDependencies: '@types/node': specifier: ^18.13.0 version: 18.13.0 - type-fest: - specifier: ^3.9.0 - version: 3.9.0 packages: /@types/node@18.13.0: resolution: {integrity: sha512-gC3TazRzGoOnoKAhUx+Q0t8S9Tzs74z7m0ipwGpSqQrleP14hKxP4/JUeEQcD3W1/aIpnWl8pHowI7WokuZpXg==} dev: true - - /type-fest@3.9.0: - resolution: {integrity: sha512-hR8JP2e8UiH7SME5JZjsobBlEiatFoxpzCP+R3ZeCo7kAaG1jXQE5X/buLzogM6GJu8le9Y4OcfNuIQX0rZskA==} - engines: {node: '>=14.16'} - dev: true diff --git a/packages/agents/tsconfig.json b/packages/agents/tsconfig.json index 2bec7cfb6..c40f32442 100644 --- a/packages/agents/tsconfig.json +++ b/packages/agents/tsconfig.json @@ -12,8 +12,9 @@ "skipLibCheck": true, "noImplicitOverride": true, "outDir": "./dist", - "declaration": true + "declaration": true, + "declarationMap": true }, - "include": ["src", "test", "index.ts", "../shared/src"], + "include": ["src", "test", "index.ts"], "exclude": ["dist"] } diff --git a/packages/agents/tsup.config.ts b/packages/agents/tsup.config.ts index 6203927ca..6be4e128a 100644 --- a/packages/agents/tsup.config.ts +++ b/packages/agents/tsup.config.ts @@ -5,9 +5,6 @@ const baseConfig: Options = { format: ["cjs", "esm"], outDir: "dist", clean: true, - dts: { - resolve: true, - }, }; const nodeConfig: Options = { diff --git a/packages/gguf/.eslintignore b/packages/gguf/.eslintignore new file mode 100644 index 000000000..53c37a166 --- /dev/null +++ b/packages/gguf/.eslintignore @@ -0,0 +1 @@ +dist \ No newline at end of file diff --git a/packages/gguf/package.json b/packages/gguf/package.json index b3c00cb40..2ab9ea38b 100644 --- a/packages/gguf/package.json +++ b/packages/gguf/package.json @@ -31,7 +31,7 @@ "format": "prettier --write .", "format:check": "prettier --check .", "prepublishOnly": "pnpm run build", - "build": "tsup src/index.ts --format cjs,esm --clean --dts", + "build": "tsup src/index.ts --format cjs,esm --clean && tsc --emitDeclarationOnly --declaration", "build:llm": "tsx scripts/generate-llm.ts && pnpm run format", "test": "vitest run", "check": "tsc" @@ -47,8 +47,5 @@ "gguf" ], "author": "Hugging Face", - "license": "MIT", - "devDependencies": { - "type-fest": "^3.9.0" - } + "license": "MIT" } diff --git a/packages/gguf/pnpm-lock.yaml b/packages/gguf/pnpm-lock.yaml index c2f96863a..2b9f1883a 100644 --- a/packages/gguf/pnpm-lock.yaml +++ b/packages/gguf/pnpm-lock.yaml @@ -1,17 +1,5 @@ lockfileVersion: '6.0' -devDependencies: - type-fest: - specifier: ^3.9.0 - version: 3.13.1 - -packages: - - /type-fest@3.13.1: - resolution: {integrity: sha512-tLq3bSNx+xSpwvAJnzrK0Ep5CLNWjvFTOp71URMaAEWBfRb9nnJiBoUe0tF8bI4ZFO3omgBR6NvnbzVUT3Ly4g==} - engines: {node: '>=14.16'} - dev: true - settings: autoInstallPeers: true excludeLinksFromLockfile: false diff --git a/packages/gguf/tsconfig.json b/packages/gguf/tsconfig.json index 37823efde..cdd24b73c 100644 --- a/packages/gguf/tsconfig.json +++ b/packages/gguf/tsconfig.json @@ -11,7 +11,9 @@ "strictNullChecks": true, "skipLibCheck": true, "noImplicitOverride": true, - "outDir": "./dist" + "outDir": "./dist", + "declaration": true, + "declarationMap": true }, "include": ["src"], "exclude": ["dist"] diff --git a/packages/gguf/tsup.config.ts b/packages/gguf/tsup.config.ts index 6203927ca..6be4e128a 100644 --- a/packages/gguf/tsup.config.ts +++ b/packages/gguf/tsup.config.ts @@ -5,9 +5,6 @@ const baseConfig: Options = { format: ["cjs", "esm"], outDir: "dist", clean: true, - dts: { - resolve: true, - }, }; const nodeConfig: Options = { diff --git a/packages/hub/README.md b/packages/hub/README.md index 9ce14e2ba..e4fcf0113 100644 --- a/packages/hub/README.md +++ b/packages/hub/README.md @@ -122,4 +122,4 @@ Under the hood, `@huggingface/hub` uses a lazy blob implementation to load the f ## Dependencies - `hash-wasm` : Only used in the browser, when committing files over 10 MB. Browsers do not natively support streaming sha256 computations. -- `type-fest` : Typings only +- `@huggingface/tasks` : Typings only diff --git a/packages/hub/package.json b/packages/hub/package.json index 4e745fb96..d288c3af4 100644 --- a/packages/hub/package.json +++ b/packages/hub/package.json @@ -33,7 +33,7 @@ "format": "prettier --write .", "format:check": "prettier --check .", "prepublishOnly": "pnpm run build", - "build": "tsup", + "build": "tsup && tsc --emitDeclarationOnly --declaration", "prepare": "pnpm run build", "test": "vitest run", "test:browser": "vitest run --browser.name=chrome --browser.headless --config vitest-browser.config.mts", @@ -56,11 +56,10 @@ "author": "Hugging Face", "license": "MIT", "devDependencies": { - "@huggingface/tasks": "workspace:^", - "@types/node": "^20.11.28", - "type-fest": "^3.9.0" + "@types/node": "^20.11.28" }, "dependencies": { + "@huggingface/tasks": "workspace:^", "hash-wasm": "^4.9.0" } } diff --git a/packages/hub/pnpm-lock.yaml b/packages/hub/pnpm-lock.yaml index 5547b15d3..0c6ef25a9 100644 --- a/packages/hub/pnpm-lock.yaml +++ b/packages/hub/pnpm-lock.yaml @@ -5,20 +5,17 @@ settings: excludeLinksFromLockfile: false dependencies: + '@huggingface/tasks': + specifier: workspace:^ + version: link:../tasks hash-wasm: specifier: ^4.9.0 version: 4.9.0 devDependencies: - '@huggingface/tasks': - specifier: workspace:^ - version: link:../tasks '@types/node': specifier: ^20.11.28 version: 20.11.28 - type-fest: - specifier: ^3.9.0 - version: 3.9.0 packages: @@ -32,11 +29,6 @@ packages: resolution: {integrity: sha512-7SW7ejyfnRxuOc7ptQHSf4LDoZaWOivfzqw+5rpcQku0nHfmicPKE51ra9BiRLAmT8+gGLestr1XroUkqdjL6w==} dev: false - /type-fest@3.9.0: - resolution: {integrity: sha512-hR8JP2e8UiH7SME5JZjsobBlEiatFoxpzCP+R3ZeCo7kAaG1jXQE5X/buLzogM6GJu8le9Y4OcfNuIQX0rZskA==} - engines: {node: '>=14.16'} - dev: true - /undici-types@5.26.5: resolution: {integrity: sha512-JlCMO+ehdEIKqlFxk6IfVoAUVmgz7cU7zD/h9XZ0qzeosSHmUJVOzSQvvYSYWXkFXC+IfLKSIffhv0sVZup6pA==} dev: true diff --git a/packages/hub/src/error.ts b/packages/hub/src/error.ts index db159b617..f0a3e33c4 100644 --- a/packages/hub/src/error.ts +++ b/packages/hub/src/error.ts @@ -1,4 +1,4 @@ -import type { JsonObject } from "type-fest"; +import type { JsonObject } from "./vendor/type-fest/basic"; export async function createApiError( response: Response, diff --git a/packages/hub/src/lib/commit.spec.ts b/packages/hub/src/lib/commit.spec.ts index e8dbeb1b1..28d46b924 100644 --- a/packages/hub/src/lib/commit.spec.ts +++ b/packages/hub/src/lib/commit.spec.ts @@ -9,7 +9,7 @@ import { deleteRepo } from "./delete-repo"; import { downloadFile } from "./download-file"; import { fileDownloadInfo } from "./file-download-info"; import { insecureRandomString } from "../utils/insecureRandomString"; -import { isFrontend } from "../../../shared"; +import { isFrontend } from "../utils/isFrontend"; const lfsContent = "O123456789".repeat(100_000); diff --git a/packages/hub/src/lib/commit.ts b/packages/hub/src/lib/commit.ts index e3690c8af..a66af74c1 100644 --- a/packages/hub/src/lib/commit.ts +++ b/packages/hub/src/lib/commit.ts @@ -1,4 +1,3 @@ -import { isFrontend, base64FromBytes } from "../../../shared"; import { HUB_URL } from "../consts"; import { HubApiError, createApiError, InvalidApiResponseFormatError } from "../error"; import type { @@ -21,6 +20,8 @@ import { toRepoId } from "../utils/toRepoId"; import { WebBlob } from "../utils/WebBlob"; import { createBlob } from "../utils/createBlob"; import { eventToGenerator } from "../utils/eventToGenerator"; +import { base64FromBytes } from "../utils/base64FromBytes"; +import { isFrontend } from "../utils/isFrontend"; const CONCURRENT_SHAS = 5; const CONCURRENT_LFS_UPLOADS = 5; diff --git a/packages/hub/src/lib/create-repo.ts b/packages/hub/src/lib/create-repo.ts index f3ab83134..2334037c3 100644 --- a/packages/hub/src/lib/create-repo.ts +++ b/packages/hub/src/lib/create-repo.ts @@ -2,7 +2,7 @@ import { HUB_URL } from "../consts"; import { createApiError } from "../error"; import type { ApiCreateRepoPayload } from "../types/api/api-create-repo"; import type { Credentials, RepoDesignation, SpaceSdk } from "../types/public"; -import { base64FromBytes } from "../../../shared"; +import { base64FromBytes } from "../utils/base64FromBytes"; import { checkCredentials } from "../utils/checkCredentials"; import { toRepoId } from "../utils/toRepoId"; diff --git a/packages/hub/src/lib/oauth-login-url.ts b/packages/hub/src/lib/oauth-login-url.ts index afb601d21..9067ba994 100644 --- a/packages/hub/src/lib/oauth-login-url.ts +++ b/packages/hub/src/lib/oauth-login-url.ts @@ -1,6 +1,6 @@ -import { base64FromBytes } from "../../../shared/src"; import { HUB_URL } from "../consts"; import { createApiError } from "../error"; +import { base64FromBytes } from "../utils/base64FromBytes"; /** * Use "Sign in with Hub" to authenticate a user, and get oauth user info / access token. diff --git a/packages/hub/src/lib/parse-safetensors-metadata.ts b/packages/hub/src/lib/parse-safetensors-metadata.ts index 1b2d35ed7..4044ece60 100644 --- a/packages/hub/src/lib/parse-safetensors-metadata.ts +++ b/packages/hub/src/lib/parse-safetensors-metadata.ts @@ -1,4 +1,3 @@ -import type { SetRequired } from "type-fest"; import type { Credentials, RepoDesignation } from "../types/public"; import { checkCredentials } from "../utils/checkCredentials"; import { omit } from "../utils/omit"; @@ -7,6 +6,7 @@ import { typedEntries } from "../utils/typedEntries"; import { downloadFile } from "./download-file"; import { fileExists } from "./file-exists"; import { promisesQueue } from "../utils/promisesQueue"; +import type { SetRequired } from "../vendor/type-fest/set-required"; export const SAFETENSORS_FILE = "model.safetensors"; export const SAFETENSORS_INDEX_FILE = "model.safetensors.index.json"; diff --git a/packages/hub/src/types/api/api-commit.d.ts b/packages/hub/src/types/api/api-commit.ts similarity index 99% rename from packages/hub/src/types/api/api-commit.d.ts rename to packages/hub/src/types/api/api-commit.ts index 7cc6ab45f..404ad5494 100644 --- a/packages/hub/src/types/api/api-commit.d.ts +++ b/packages/hub/src/types/api/api-commit.ts @@ -149,7 +149,7 @@ export interface ApiCommitDeletedEntry { path: string; } -interface ApiCommitLfsFile { +export interface ApiCommitLfsFile { path: string; oldPath?: string; /** Required if {@link oldPath} is not set */ diff --git a/packages/hub/src/types/api/api-create-repo.d.ts b/packages/hub/src/types/api/api-create-repo.ts similarity index 76% rename from packages/hub/src/types/api/api-create-repo.d.ts rename to packages/hub/src/types/api/api-create-repo.ts index 3ba8df798..f701f2d52 100644 --- a/packages/hub/src/types/api/api-create-repo.d.ts +++ b/packages/hub/src/types/api/api-create-repo.ts @@ -1,5 +1,5 @@ -import type { SetRequired } from "type-fest"; -import type { SpaceHardwareFlavor, SpaceSdk } from "../public"; +import type { SetRequired } from "../../vendor/type-fest/set-required"; +import type { RepoType, SpaceHardwareFlavor, SpaceSdk } from "../public"; import type { ApiCommitFile } from "./api-commit"; export type ApiCreateRepoPayload = { diff --git a/packages/hub/src/types/api/api-dataset.d.ts b/packages/hub/src/types/api/api-dataset.ts similarity index 100% rename from packages/hub/src/types/api/api-dataset.d.ts rename to packages/hub/src/types/api/api-dataset.ts diff --git a/packages/hub/src/types/api/api-index-tree.d.ts b/packages/hub/src/types/api/api-index-tree.ts similarity index 92% rename from packages/hub/src/types/api/api-index-tree.d.ts rename to packages/hub/src/types/api/api-index-tree.ts index a43b6e557..a467218cf 100644 --- a/packages/hub/src/types/api/api-index-tree.d.ts +++ b/packages/hub/src/types/api/api-index-tree.ts @@ -27,7 +27,7 @@ export interface ApiFileScanResult { pickleImportScan?: ApiPickleImportScan; } -interface AVScan { +interface ApiAVScan { virusFound: boolean; virusNames?: string[]; } @@ -41,6 +41,6 @@ interface ApiPickleImport { } interface ApiPickleImportScan { - highestSafetyLevel: ApiSafetyLevelafetyLevel; + highestSafetyLevel: ApiSafetyLevel; imports: ApiPickleImport[]; } diff --git a/packages/hub/src/types/api/api-model.d.ts b/packages/hub/src/types/api/api-model.ts similarity index 100% rename from packages/hub/src/types/api/api-model.d.ts rename to packages/hub/src/types/api/api-model.ts diff --git a/packages/hub/src/types/api/api-space.d.ts b/packages/hub/src/types/api/api-space.ts similarity index 100% rename from packages/hub/src/types/api/api-space.d.ts rename to packages/hub/src/types/api/api-space.ts diff --git a/packages/hub/src/types/api/api-who-am-i.d.ts b/packages/hub/src/types/api/api-who-am-i.ts similarity index 100% rename from packages/hub/src/types/api/api-who-am-i.d.ts rename to packages/hub/src/types/api/api-who-am-i.ts diff --git a/packages/hub/src/types/public.d.ts b/packages/hub/src/types/public.ts similarity index 100% rename from packages/hub/src/types/public.d.ts rename to packages/hub/src/types/public.ts diff --git a/packages/hub/src/utils/WebBlob.spec.ts b/packages/hub/src/utils/WebBlob.spec.ts index d5efd4f5c..75687ae1f 100644 --- a/packages/hub/src/utils/WebBlob.spec.ts +++ b/packages/hub/src/utils/WebBlob.spec.ts @@ -1,6 +1,6 @@ import { describe, expect, it, beforeAll } from "vitest"; -import { base64FromBytes } from "../../../shared"; import { WebBlob } from "./WebBlob"; +import { base64FromBytes } from "./base64FromBytes"; describe("WebBlob", () => { const resourceUrl = new URL("https://huggingface.co/spaces/aschen/push-model-from-web/raw/main/mobilenet/model.json"); diff --git a/packages/shared/src/base64FromBytes.ts b/packages/hub/src/utils/base64FromBytes.ts similarity index 100% rename from packages/shared/src/base64FromBytes.ts rename to packages/hub/src/utils/base64FromBytes.ts diff --git a/packages/hub/src/utils/createBlob.ts b/packages/hub/src/utils/createBlob.ts index 35bf5f18b..0cf54206d 100644 --- a/packages/hub/src/utils/createBlob.ts +++ b/packages/hub/src/utils/createBlob.ts @@ -1,5 +1,5 @@ -import { isFrontend } from "../../../shared"; import { WebBlob } from "./WebBlob"; +import { isFrontend } from "./isFrontend"; /** * This function allow to retrieve either a FileBlob or a WebBlob from a URL. diff --git a/packages/shared/src/isBackend.ts b/packages/hub/src/utils/isBackend.ts similarity index 100% rename from packages/shared/src/isBackend.ts rename to packages/hub/src/utils/isBackend.ts diff --git a/packages/shared/src/isFrontend.ts b/packages/hub/src/utils/isFrontend.ts similarity index 100% rename from packages/shared/src/isFrontend.ts rename to packages/hub/src/utils/isFrontend.ts diff --git a/packages/hub/src/utils/sha256.ts b/packages/hub/src/utils/sha256.ts index e9e9f1cca..60c9dfdaa 100644 --- a/packages/hub/src/utils/sha256.ts +++ b/packages/hub/src/utils/sha256.ts @@ -1,6 +1,6 @@ -import { isFrontend } from "../../../shared"; import { eventToGenerator } from "./eventToGenerator"; import { hexFromBytes } from "./hexFromBytes"; +import { isFrontend } from "./isFrontend"; const webWorkerCode = ` // Would prefer no CDN, but need a clever way to not burden the main file of the bundle diff --git a/packages/hub/src/utils/typedEntries.ts b/packages/hub/src/utils/typedEntries.ts index ee6343b3a..031ba7daa 100644 --- a/packages/hub/src/utils/typedEntries.ts +++ b/packages/hub/src/utils/typedEntries.ts @@ -1,4 +1,4 @@ -import type { Entries } from "type-fest"; +import type { Entries } from "../vendor/type-fest/entries"; export function typedEntries>(obj: T): Entries { return Object.entries(obj) as Entries; diff --git a/packages/hub/src/vendor/type-fest/basic.ts b/packages/hub/src/vendor/type-fest/basic.ts new file mode 100644 index 000000000..3fa40a039 --- /dev/null +++ b/packages/hub/src/vendor/type-fest/basic.ts @@ -0,0 +1,31 @@ +/** +Matches a JSON object. + +This type can be useful to enforce some input to be JSON-compatible or as a super-type to be extended from. Don't use this as a direct return type as the user would have to double-cast it: `jsonObject as unknown as CustomResponse`. Instead, you could extend your CustomResponse type from it to ensure your type only uses JSON-compatible types: `interface CustomResponse extends JsonObject { … }`. + +@category JSON +*/ +export type JsonObject = { [Key in string]: JsonValue } & { [Key in string]?: JsonValue | undefined }; + +/** +Matches a JSON array. + +@category JSON +*/ +export type JsonArray = JsonValue[] | readonly JsonValue[]; + +/** +Matches any valid JSON primitive value. + +@category JSON +*/ +export type JsonPrimitive = string | number | boolean | null; + +/** +Matches any valid JSON value. + +@see `Jsonify` if you need to transform a type to one that is assignable to `JsonValue`. + +@category JSON +*/ +export type JsonValue = JsonPrimitive | JsonObject | JsonArray; diff --git a/packages/hub/src/vendor/type-fest/entries.ts b/packages/hub/src/vendor/type-fest/entries.ts new file mode 100644 index 000000000..7716e4748 --- /dev/null +++ b/packages/hub/src/vendor/type-fest/entries.ts @@ -0,0 +1,65 @@ +import type { ArrayEntry, MapEntry, ObjectEntry, SetEntry } from "./entry"; + +type ArrayEntries = Array>; +type MapEntries = Array>; +type ObjectEntries = Array>; +type SetEntries> = Array>; + +/** +Many collections have an `entries` method which returns an array of a given object's own enumerable string-keyed property [key, value] pairs. The `Entries` type will return the type of that collection's entries. + +For example the {@link https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Object/entries|`Object`}, {@link https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Map/entries|`Map`}, {@link https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Array/entries|`Array`}, and {@link https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Set/entries|`Set`} collections all have this method. Note that `WeakMap` and `WeakSet` do not have this method since their entries are not enumerable. + +@see `Entry` if you want to just access the type of a single entry. + +@example +``` +import type {Entries} from 'type-fest'; + +interface Example { + someKey: number; +} + +const manipulatesEntries = (examples: Entries) => examples.map(example => [ + // Does some arbitrary processing on the key (with type information available) + example[0].toUpperCase(), + + // Does some arbitrary processing on the value (with type information available) + example[1].toFixed() +]); + +const example: Example = {someKey: 1}; +const entries = Object.entries(example) as Entries; +const output = manipulatesEntries(entries); + +// Objects +const objectExample = {a: 1}; +const objectEntries: Entries = [['a', 1]]; + +// Arrays +const arrayExample = ['a', 1]; +const arrayEntries: Entries = [[0, 'a'], [1, 1]]; + +// Maps +const mapExample = new Map([['a', 1]]); +const mapEntries: Entries = [['a', 1]]; + +// Sets +const setExample = new Set(['a', 1]); +const setEntries: Entries = [['a', 'a'], [1, 1]]; +``` + +@category Object +@category Map +@category Set +@category Array +*/ +export type Entries = BaseType extends Map + ? MapEntries + : BaseType extends Set + ? SetEntries + : BaseType extends readonly unknown[] + ? ArrayEntries + : BaseType extends object + ? ObjectEntries + : never; diff --git a/packages/hub/src/vendor/type-fest/entry.ts b/packages/hub/src/vendor/type-fest/entry.ts new file mode 100644 index 000000000..ed3650c90 --- /dev/null +++ b/packages/hub/src/vendor/type-fest/entry.ts @@ -0,0 +1,68 @@ +type MapKey = BaseType extends Map ? KeyType : never; +type MapValue = BaseType extends Map ? ValueType : never; + +export type ArrayEntry = [number, BaseType[number]]; +export type MapEntry = [MapKey, MapValue]; +export type ObjectEntry = [keyof BaseType, BaseType[keyof BaseType]]; +export type SetEntry = BaseType extends Set ? [ItemType, ItemType] : never; + +/** +Many collections have an `entries` method which returns an array of a given object's own enumerable string-keyed property [key, value] pairs. The `Entry` type will return the type of that collection's entry. + +For example the {@link https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Object/entries|`Object`}, {@link https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Map/entries|`Map`}, {@link https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Array/entries|`Array`}, and {@link https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Set/entries|`Set`} collections all have this method. Note that `WeakMap` and `WeakSet` do not have this method since their entries are not enumerable. + +@see `Entries` if you want to just access the type of the array of entries (which is the return of the `.entries()` method). + +@example +``` +import type {Entry} from 'type-fest'; + +interface Example { + someKey: number; +} + +const manipulatesEntry = (example: Entry) => [ + // Does some arbitrary processing on the key (with type information available) + example[0].toUpperCase(), + + // Does some arbitrary processing on the value (with type information available) + example[1].toFixed(), +]; + +const example: Example = {someKey: 1}; +const entry = Object.entries(example)[0] as Entry; +const output = manipulatesEntry(entry); + +// Objects +const objectExample = {a: 1}; +const objectEntry: Entry = ['a', 1]; + +// Arrays +const arrayExample = ['a', 1]; +const arrayEntryString: Entry = [0, 'a']; +const arrayEntryNumber: Entry = [1, 1]; + +// Maps +const mapExample = new Map([['a', 1]]); +const mapEntry: Entry = ['a', 1]; + +// Sets +const setExample = new Set(['a', 1]); +const setEntryString: Entry = ['a', 'a']; +const setEntryNumber: Entry = [1, 1]; +``` + +@category Object +@category Map +@category Array +@category Set +*/ +export type Entry = BaseType extends Map + ? MapEntry + : BaseType extends Set + ? SetEntry + : BaseType extends readonly unknown[] + ? ArrayEntry + : BaseType extends object + ? ObjectEntry + : never; diff --git a/packages/hub/src/vendor/type-fest/except.ts b/packages/hub/src/vendor/type-fest/except.ts new file mode 100644 index 000000000..b18f739d1 --- /dev/null +++ b/packages/hub/src/vendor/type-fest/except.ts @@ -0,0 +1,71 @@ +import type { IsEqual } from "./is-equal"; + +/** +Filter out keys from an object. + +Returns `never` if `Exclude` is strictly equal to `Key`. +Returns `never` if `Key` extends `Exclude`. +Returns `Key` otherwise. + +@example +``` +type Filtered = Filter<'foo', 'foo'>; +//=> never +``` + +@example +``` +type Filtered = Filter<'bar', string>; +//=> never +``` + +@example +``` +type Filtered = Filter<'bar', 'foo'>; +//=> 'bar' +``` + +@see {Except} +*/ +type Filter = IsEqual extends true + ? never + : KeyType extends ExcludeType + ? never + : KeyType; + +/** +Create a type from an object type without certain keys. + +We recommend setting the `requireExactProps` option to `true`. + +This type is a stricter version of [`Omit`](https://www.typescriptlang.org/docs/handbook/release-notes/typescript-3-5.html#the-omit-helper-type). The `Omit` type does not restrict the omitted keys to be keys present on the given type, while `Except` does. The benefits of a stricter type are avoiding typos and allowing the compiler to pick up on rename refactors automatically. + +This type was proposed to the TypeScript team, which declined it, saying they prefer that libraries implement stricter versions of the built-in types ([microsoft/TypeScript#30825](https://github.com/microsoft/TypeScript/issues/30825#issuecomment-523668235)). + +@example +``` +import type {Except} from 'type-fest'; + +type Foo = { + a: number; + b: string; +}; + +type FooWithoutA = Except; +//=> {b: string} + +const fooWithoutA: FooWithoutA = {a: 1, b: '2'}; +//=> errors: 'a' does not exist in type '{ b: string; }' + +type FooWithoutB = Except; +//=> {a: number} & Partial> + +const fooWithoutB: FooWithoutB = {a: 1, b: '2'}; +//=> errors at 'b': Type 'string' is not assignable to type 'undefined'. +``` + +@category Object +*/ +export type Except = { + [KeyType in keyof ObjectType as Filter]: ObjectType[KeyType]; +}; diff --git a/packages/hub/src/vendor/type-fest/is-equal.ts b/packages/hub/src/vendor/type-fest/is-equal.ts new file mode 100644 index 000000000..d6ff2e53c --- /dev/null +++ b/packages/hub/src/vendor/type-fest/is-equal.ts @@ -0,0 +1,27 @@ +/** +Returns a boolean for whether the two given types are equal. + +@link https://github.com/microsoft/TypeScript/issues/27024#issuecomment-421529650 +@link https://stackoverflow.com/questions/68961864/how-does-the-equals-work-in-typescript/68963796#68963796 + +Use-cases: +- If you want to make a conditional branch based on the result of a comparison of two types. + +@example +``` +import type {IsEqual} from 'type-fest'; + +// This type returns a boolean for whether the given array includes the given item. +// `IsEqual` is used to compare the given array at position 0 and the given item and then return true if they are equal. +type Includes = + Value extends readonly [Value[0], ...infer rest] + ? IsEqual extends true + ? true + : Includes + : false; +``` + +@category Type Guard +@category Utilities +*/ +export type IsEqual = (() => G extends A ? 1 : 2) extends () => G extends B ? 1 : 2 ? true : false; diff --git a/packages/hub/src/vendor/type-fest/set-required.ts b/packages/hub/src/vendor/type-fest/set-required.ts new file mode 100644 index 000000000..8e4c6417a --- /dev/null +++ b/packages/hub/src/vendor/type-fest/set-required.ts @@ -0,0 +1,34 @@ +import type { Except } from "./except"; +import type { Simplify } from "./simplify"; + +/** +Create a type that makes the given keys required. The remaining keys are kept as is. The sister of the `SetOptional` type. + +Use-case: You want to define a single model where the only thing that changes is whether or not some of the keys are required. + +@example +``` +import type {SetRequired} from 'type-fest'; + +type Foo = { + a?: number; + b: string; + c?: boolean; +} + +type SomeRequired = SetRequired; +// type SomeRequired = { +// a?: number; +// b: string; // Was already required and still is. +// c: boolean; // Is now required. +// } +``` + +@category Object +*/ +export type SetRequired = Simplify< + // Pick just the keys that are optional from the base type. + Except & + // Pick the keys that should be required from the base type and make them required. + Required> +>; diff --git a/packages/hub/src/vendor/type-fest/simplify.ts b/packages/hub/src/vendor/type-fest/simplify.ts new file mode 100644 index 000000000..f4564fe70 --- /dev/null +++ b/packages/hub/src/vendor/type-fest/simplify.ts @@ -0,0 +1,59 @@ +/** +Useful to flatten the type output to improve type hints shown in editors. And also to transform an interface into a type to aide with assignability. + +@example +``` +import type {Simplify} from 'type-fest'; + +type PositionProps = { + top: number; + left: number; +}; + +type SizeProps = { + width: number; + height: number; +}; + +// In your editor, hovering over `Props` will show a flattened object with all the properties. +type Props = Simplify; +``` + +Sometimes it is desired to pass a value as a function argument that has a different type. At first inspection it may seem assignable, and then you discover it is not because the `value`'s type definition was defined as an interface. In the following example, `fn` requires an argument of type `Record`. If the value is defined as a literal, then it is assignable. And if the `value` is defined as type using the `Simplify` utility the value is assignable. But if the `value` is defined as an interface, it is not assignable because the interface is not sealed and elsewhere a non-string property could be added to the interface. + +If the type definition must be an interface (perhaps it was defined in a third-party npm package), then the `value` can be defined as `const value: Simplify = ...`. Then `value` will be assignable to the `fn` argument. Or the `value` can be cast as `Simplify` if you can't re-declare the `value`. + +@example +``` +import type {Simplify} from 'type-fest'; + +interface SomeInterface { + foo: number; + bar?: string; + baz: number | undefined; +} + +type SomeType = { + foo: number; + bar?: string; + baz: number | undefined; +}; + +const literal = {foo: 123, bar: 'hello', baz: 456}; +const someType: SomeType = literal; +const someInterface: SomeInterface = literal; + +function fn(object: Record): void {} + +fn(literal); // Good: literal object type is sealed +fn(someType); // Good: type is sealed +fn(someInterface); // Error: Index signature for type 'string' is missing in type 'someInterface'. Because `interface` can be re-opened +fn(someInterface as Simplify); // Good: transform an `interface` into a `type` +``` + +@link https://github.com/microsoft/TypeScript/issues/15300 + +@category Object +*/ +// eslint-disable-next-line @typescript-eslint/ban-types +export type Simplify = { [KeyType in keyof T]: T[KeyType] } & {}; diff --git a/packages/hub/tsconfig.json b/packages/hub/tsconfig.json index 373d47165..254606a30 100644 --- a/packages/hub/tsconfig.json +++ b/packages/hub/tsconfig.json @@ -11,8 +11,10 @@ "strictNullChecks": true, "skipLibCheck": true, "noImplicitOverride": true, - "outDir": "./dist" + "outDir": "./dist", + "declaration": true, + "declarationMap": true }, - "include": ["src", "index.ts", "../shared/src"], + "include": ["src", "index.ts"], "exclude": ["dist"] } diff --git a/packages/hub/tsup.config.ts b/packages/hub/tsup.config.ts index 6203927ca..6be4e128a 100644 --- a/packages/hub/tsup.config.ts +++ b/packages/hub/tsup.config.ts @@ -5,9 +5,6 @@ const baseConfig: Options = { format: ["cjs", "esm"], outDir: "dist", clean: true, - dts: { - resolve: true, - }, }; const nodeConfig: Options = { diff --git a/packages/inference/README.md b/packages/inference/README.md index 99e50f048..eb36138e3 100644 --- a/packages/inference/README.md +++ b/packages/inference/README.md @@ -532,3 +532,7 @@ HF_TOKEN="your access token" pnpm run test We have an informative documentation project called [Tasks](https://huggingface.co/tasks) to list available models for each task and explain how each task works in detail. It also contains demos, example outputs, and other resources should you want to dig deeper into the ML side of things. + +## Dependencies + +- `@huggingface/tasks` : Typings only diff --git a/packages/inference/package.json b/packages/inference/package.json index a5a26d102..2e012d4f5 100644 --- a/packages/inference/package.json +++ b/packages/inference/package.json @@ -29,17 +29,17 @@ "src" ], "source": "src/index.ts", - "types": "./dist/index.d.ts", + "types": "./dist/src/index.d.ts", "main": "./dist/index.cjs", "module": "./dist/index.js", "exports": { - "types": "./dist/index.d.ts", + "types": "./dist/src/index.d.ts", "require": "./dist/index.cjs", "import": "./dist/index.js" }, "type": "module", "scripts": { - "build": "tsup src/index.ts --format cjs,esm --clean && pnpm run dts", + "build": "tsup src/index.ts --format cjs,esm --clean && tsc --emitDeclarationOnly --declaration", "dts": "tsx scripts/generate-dts.ts && tsc --noEmit dist/index.d.ts", "lint": "eslint --quiet --fix --ext .cjs,.ts .", "lint:check": "eslint --ext .cjs,.ts .", diff --git a/packages/inference/src/tasks/cv/imageToImage.ts b/packages/inference/src/tasks/cv/imageToImage.ts index c96dce363..5c18ccb11 100644 --- a/packages/inference/src/tasks/cv/imageToImage.ts +++ b/packages/inference/src/tasks/cv/imageToImage.ts @@ -1,7 +1,7 @@ import { InferenceOutputError } from "../../lib/InferenceOutputError"; import type { BaseArgs, Options, RequestArgs } from "../../types"; +import { base64FromBytes } from "../../utils/base64FromBytes"; import { request } from "../custom/request"; -import { base64FromBytes } from "../../../../shared"; export type ImageToImageArgs = BaseArgs & { /** diff --git a/packages/inference/src/tasks/cv/zeroShotImageClassification.ts b/packages/inference/src/tasks/cv/zeroShotImageClassification.ts index cb2b8f0d6..062b86b21 100644 --- a/packages/inference/src/tasks/cv/zeroShotImageClassification.ts +++ b/packages/inference/src/tasks/cv/zeroShotImageClassification.ts @@ -2,7 +2,7 @@ import { InferenceOutputError } from "../../lib/InferenceOutputError"; import type { BaseArgs, Options } from "../../types"; import { request } from "../custom/request"; import type { RequestArgs } from "../../types"; -import { base64FromBytes } from "../../../../shared"; +import { base64FromBytes } from "../../utils/base64FromBytes"; export type ZeroShotImageClassificationArgs = BaseArgs & { inputs: { diff --git a/packages/inference/src/tasks/multimodal/documentQuestionAnswering.ts b/packages/inference/src/tasks/multimodal/documentQuestionAnswering.ts index f5f993137..205e956b9 100644 --- a/packages/inference/src/tasks/multimodal/documentQuestionAnswering.ts +++ b/packages/inference/src/tasks/multimodal/documentQuestionAnswering.ts @@ -2,8 +2,8 @@ import { InferenceOutputError } from "../../lib/InferenceOutputError"; import type { BaseArgs, Options } from "../../types"; import { request } from "../custom/request"; import type { RequestArgs } from "../../types"; -import { base64FromBytes } from "../../../../shared"; import { toArray } from "../../utils/toArray"; +import { base64FromBytes } from "../../utils/base64FromBytes"; export type DocumentQuestionAnsweringArgs = BaseArgs & { inputs: { diff --git a/packages/inference/src/tasks/multimodal/visualQuestionAnswering.ts b/packages/inference/src/tasks/multimodal/visualQuestionAnswering.ts index ec45a0fa0..80e8a9a15 100644 --- a/packages/inference/src/tasks/multimodal/visualQuestionAnswering.ts +++ b/packages/inference/src/tasks/multimodal/visualQuestionAnswering.ts @@ -1,7 +1,7 @@ import { InferenceOutputError } from "../../lib/InferenceOutputError"; import type { BaseArgs, Options, RequestArgs } from "../../types"; +import { base64FromBytes } from "../../utils/base64FromBytes"; import { request } from "../custom/request"; -import { base64FromBytes } from "../../../../shared"; export type VisualQuestionAnsweringArgs = BaseArgs & { inputs: { diff --git a/packages/inference/src/utils/base64FromBytes.ts b/packages/inference/src/utils/base64FromBytes.ts new file mode 100644 index 000000000..5327bbfe2 --- /dev/null +++ b/packages/inference/src/utils/base64FromBytes.ts @@ -0,0 +1,11 @@ +export function base64FromBytes(arr: Uint8Array): string { + if (globalThis.Buffer) { + return globalThis.Buffer.from(arr).toString("base64"); + } else { + const bin: string[] = []; + arr.forEach((byte) => { + bin.push(String.fromCharCode(byte)); + }); + return globalThis.btoa(bin.join("")); + } +} diff --git a/packages/inference/src/utils/distributive-omit.d.ts b/packages/inference/src/utils/distributive-omit.ts similarity index 84% rename from packages/inference/src/utils/distributive-omit.d.ts rename to packages/inference/src/utils/distributive-omit.ts index c7edf2cd3..1f2536c3e 100644 --- a/packages/inference/src/utils/distributive-omit.d.ts +++ b/packages/inference/src/utils/distributive-omit.ts @@ -4,8 +4,6 @@ * This allows omitting keys from objects inside unions, without merging the individual components of the union. */ -type Keys = keyof T; -type DistributiveKeys = T extends unknown ? Keys : never; type Omit_ = Omit>; export type DistributiveOmit = T extends unknown diff --git a/packages/inference/src/utils/isBackend.ts b/packages/inference/src/utils/isBackend.ts new file mode 100644 index 000000000..1e6f27998 --- /dev/null +++ b/packages/inference/src/utils/isBackend.ts @@ -0,0 +1,6 @@ +const isBrowser = typeof window !== "undefined" && typeof window.document !== "undefined"; + +const isWebWorker = + typeof self === "object" && self.constructor && self.constructor.name === "DedicatedWorkerGlobalScope"; + +export const isBackend = !isBrowser && !isWebWorker; diff --git a/packages/inference/src/utils/isFrontend.ts b/packages/inference/src/utils/isFrontend.ts new file mode 100644 index 000000000..0b9bab392 --- /dev/null +++ b/packages/inference/src/utils/isFrontend.ts @@ -0,0 +1,3 @@ +import { isBackend } from "./isBackend"; + +export const isFrontend = !isBackend; diff --git a/packages/inference/test/vcr.ts b/packages/inference/test/vcr.ts index 6f840f44f..9b8140969 100644 --- a/packages/inference/test/vcr.ts +++ b/packages/inference/test/vcr.ts @@ -1,6 +1,7 @@ import { omit } from "../src/utils/omit"; -import { isBackend, isFrontend } from "../../shared"; import { HF_HUB_URL } from "../src/lib/getDefaultTask"; +import { isBackend } from "../src/utils/isBackend"; +import { isFrontend } from "../src/utils/isFrontend"; const TAPES_FILE = "./tapes.json"; const BASE64_PREFIX = "data:application/octet-stream;base64,"; diff --git a/packages/inference/tsconfig.json b/packages/inference/tsconfig.json index 8b8068306..4de007d35 100644 --- a/packages/inference/tsconfig.json +++ b/packages/inference/tsconfig.json @@ -1,7 +1,6 @@ { "compilerOptions": { "esModuleInterop": true, - "noEmit": true, "module": "ESNext", "target": "ESNext", "moduleResolution": "Node", @@ -9,8 +8,11 @@ "strict": true, "strictNullChecks": true, "skipLibCheck": true, - "noImplicitOverride": true + "noImplicitOverride": true, + "declaration": true, + "declarationMap": true, + "outDir": "./dist" }, - "include": ["src", "test", "index.ts", "../shared/src"], + "include": ["src", "test"], "exclude": ["dist"] } diff --git a/packages/jinja/package.json b/packages/jinja/package.json index 548f7e655..ae36c286d 100644 --- a/packages/jinja/package.json +++ b/packages/jinja/package.json @@ -29,7 +29,7 @@ "format:check": "prettier --check .", "prepublishOnly": "pnpm run build", "prepare": "pnpm run build", - "build": "tsup src/index.ts --format cjs,esm --clean --dts", + "build": "tsup src/index.ts --format cjs,esm --clean && tsc --emitDeclarationOnly --declaration", "test": "vitest run", "test:browser": "vitest run --browser.name=chrome --browser.headless", "check": "tsc" diff --git a/packages/jinja/tsconfig.json b/packages/jinja/tsconfig.json index 4a366c4e6..70b837ccc 100644 --- a/packages/jinja/tsconfig.json +++ b/packages/jinja/tsconfig.json @@ -12,7 +12,8 @@ "skipLibCheck": true, "noImplicitOverride": true, "outDir": "./dist", - "declaration": true + "declaration": true, + "declarationMap": true }, "include": ["src", "index.ts"], "exclude": ["dist"] diff --git a/packages/languages/package.json b/packages/languages/package.json index 479ad2501..998856cb4 100644 --- a/packages/languages/package.json +++ b/packages/languages/package.json @@ -24,7 +24,7 @@ "format": "prettier --write .", "format:check": "prettier --check .", "prepublishOnly": "pnpm run build", - "build": "tsup src/index.ts --format cjs,esm --clean --dts", + "build": "tsup src/index.ts --format cjs,esm --clean && tsc --emitDeclarationOnly --declaration", "test": "vitest run", "check": "tsc" }, diff --git a/packages/languages/tsconfig.json b/packages/languages/tsconfig.json index 37823efde..cdd24b73c 100644 --- a/packages/languages/tsconfig.json +++ b/packages/languages/tsconfig.json @@ -11,7 +11,9 @@ "strictNullChecks": true, "skipLibCheck": true, "noImplicitOverride": true, - "outDir": "./dist" + "outDir": "./dist", + "declaration": true, + "declarationMap": true }, "include": ["src"], "exclude": ["dist"] diff --git a/packages/shared/package.json b/packages/shared/package.json deleted file mode 100644 index 292106143..000000000 --- a/packages/shared/package.json +++ /dev/null @@ -1,8 +0,0 @@ -{ - "name": "@huggingface/shared", - "version": "1.0.0", - "private": true, - "main": "src/index.ts", - "source": "src/index.ts", - "types": "./src/index.ts" -} \ No newline at end of file diff --git a/packages/shared/pnpm-lock.yaml b/packages/shared/pnpm-lock.yaml deleted file mode 100644 index 2b9f1883a..000000000 --- a/packages/shared/pnpm-lock.yaml +++ /dev/null @@ -1,5 +0,0 @@ -lockfileVersion: '6.0' - -settings: - autoInstallPeers: true - excludeLinksFromLockfile: false diff --git a/packages/shared/src/index.ts b/packages/shared/src/index.ts deleted file mode 100644 index 00fd31dd0..000000000 --- a/packages/shared/src/index.ts +++ /dev/null @@ -1,3 +0,0 @@ -export * from './base64FromBytes'; -export * from './isBackend'; -export * from './isFrontend'; diff --git a/packages/shared/tsconfig.json b/packages/shared/tsconfig.json deleted file mode 100644 index 1ab94125e..000000000 --- a/packages/shared/tsconfig.json +++ /dev/null @@ -1,14 +0,0 @@ -{ - "compilerOptions": { - "esModuleInterop": true, - "noEmit": false, - "module": "ESNext", - "target": "ESNext", - "moduleResolution": "Node", - "noImplicitAny": true, - "strict": true, - "strictNullChecks": true, - "skipLibCheck": true, - "composite": true - } -} diff --git a/packages/tasks/package.json b/packages/tasks/package.json index d18df0486..b8d8a4849 100644 --- a/packages/tasks/package.json +++ b/packages/tasks/package.json @@ -9,10 +9,10 @@ }, "main": "./dist/index.cjs", "module": "./dist/index.js", - "types": "./dist/index.d.ts", + "types": "./dist/src/index.d.ts", "exports": { ".": { - "types": "./dist/index.d.ts", + "types": "./dist/src/index.d.ts", "require": "./dist/index.cjs", "import": "./dist/index.js" } @@ -23,8 +23,8 @@ "lint:check": "eslint --ext .cjs,.ts .", "format": "prettier --write .", "format:check": "prettier --check .", - "prepublishOnly": "pnpm run build", - "build": "tsup src/index.ts --format cjs,esm --clean --dts && pnpm run inference-codegen", + "prepublishOnly": "pnpm run inference-codegen && git diff --name-only --exit-code src && pnpm run build", + "build": "tsup src/index.ts --format cjs,esm --clean && tsc --emitDeclarationOnly --declaration", "prepare": "pnpm run build", "check": "tsc", "inference-codegen": "tsx scripts/inference-codegen.ts && prettier --write src/tasks/*/inference.ts", diff --git a/packages/tasks/tsconfig.json b/packages/tasks/tsconfig.json index 1ef9d0d37..6a2bad758 100644 --- a/packages/tasks/tsconfig.json +++ b/packages/tasks/tsconfig.json @@ -11,7 +11,9 @@ "strictNullChecks": true, "skipLibCheck": true, "noImplicitOverride": true, - "outDir": "./dist" + "outDir": "./dist", + "declaration": true, + "declarationMap": true }, "include": ["src", "scripts"], "exclude": ["dist"] diff --git a/packages/widgets/tsconfig.json b/packages/widgets/tsconfig.json index 6f788f160..0f47472f7 100644 --- a/packages/widgets/tsconfig.json +++ b/packages/widgets/tsconfig.json @@ -8,8 +8,6 @@ "resolveJsonModule": true, "skipLibCheck": true, "sourceMap": true, - "strict": true, - "module": "NodeNext", - "moduleResolution": "NodeNext" + "strict": true } } diff --git a/packages/widgets/vite.config.ts b/packages/widgets/vite.config.ts index f36295990..0b4714597 100644 --- a/packages/widgets/vite.config.ts +++ b/packages/widgets/vite.config.ts @@ -25,6 +25,7 @@ export default defineConfig(({ mode }) => { emitCss: false, compilerOptions: { hydratable: true, + // @ts-expect-error to check cc @krampstudio generate: isSSR ? "ssr" : "dom", }, }), diff --git a/pnpm-workspace.yaml b/pnpm-workspace.yaml index fe48f2587..45131d274 100644 --- a/pnpm-workspace.yaml +++ b/pnpm-workspace.yaml @@ -2,7 +2,6 @@ packages: - "packages/hub" - "packages/inference" - "packages/doc-internal" - - "packages/shared" - "packages/agents" - "packages/languages" - "packages/tasks"