From 731f01df9afb94574df58a1cbe1c2a5e12bd2b9c Mon Sep 17 00:00:00 2001 From: coyotte508 Date: Mon, 6 May 2024 16:36:30 +0200 Subject: [PATCH 01/14] =?UTF-8?q?=E2=99=BB=EF=B8=8F=20Make=20"go=20to=20so?= =?UTF-8?q?urce=20definition"=20work?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .github/workflows/hub-publish.yml | 38 ++++++++++ packages/agents/package.json | 5 +- packages/agents/tsconfig.json | 5 +- packages/agents/tsup.config.ts | 3 - packages/gguf/package.json | 7 +- packages/gguf/tsconfig.json | 4 +- packages/gguf/tsup.config.ts | 3 - packages/hub/README.md | 2 +- packages/hub/package.json | 7 +- 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} | 2 +- .../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/vendor/type-fest/basic.ts | 31 ++++++++ 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 | 35 +++++++++ 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 | 2 +- .../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 | 4 +- packages/tasks/tsconfig.json | 4 +- pnpm-workspace.yaml | 1 - 59 files changed, 341 insertions(+), 89 deletions(-) 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} (87%) 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/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/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/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/package.json b/packages/gguf/package.json index ab1fc993e..79e22ef24 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/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/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 87% 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..23147c6bf 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 { 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/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/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..d25e6e0d8 --- /dev/null +++ b/packages/hub/src/vendor/type-fest/set-required.ts @@ -0,0 +1,35 @@ +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..0d1be0708 100644 --- a/packages/inference/package.json +++ b/packages/inference/package.json @@ -39,7 +39,7 @@ }, "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..88dd38c3d 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", "index.ts"], "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..2cd71b517 100644 --- a/packages/tasks/package.json +++ b/packages/tasks/package.json @@ -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 && 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/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" From 20273f5c3f4501a792c53920747381a212fefda3 Mon Sep 17 00:00:00 2001 From: coyotte508 Date: Mon, 6 May 2024 16:44:27 +0200 Subject: [PATCH 02/14] =?UTF-8?q?=F0=9F=93=A6=20Update=20lockfiles?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- packages/agents/pnpm-lock.yaml | 8 -------- packages/gguf/pnpm-lock.yaml | 12 ------------ packages/hub/pnpm-lock.yaml | 14 +++----------- packages/tasks/package.json | 4 ++-- 4 files changed, 5 insertions(+), 33 deletions(-) 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/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/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/tasks/package.json b/packages/tasks/package.json index 2cd71b517..2b77cb7c8 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" } From b07184a38c82eb0fee500123656fcfa4ad7a32d4 Mon Sep 17 00:00:00 2001 From: coyotte508 Date: Mon, 6 May 2024 16:50:18 +0200 Subject: [PATCH 03/14] =?UTF-8?q?=E2=9E=95=20Add=20missing=20files?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- packages/hub/src/types/api/api-create-repo.ts | 2 +- packages/hub/src/utils/typedEntries.ts | 2 +- packages/hub/src/vendor/type-fest/entries.ts | 65 +++++++++++++++++++ packages/hub/src/vendor/type-fest/entry.ts | 65 +++++++++++++++++++ 4 files changed, 132 insertions(+), 2 deletions(-) create mode 100644 packages/hub/src/vendor/type-fest/entries.ts create mode 100644 packages/hub/src/vendor/type-fest/entry.ts diff --git a/packages/hub/src/types/api/api-create-repo.ts b/packages/hub/src/types/api/api-create-repo.ts index 23147c6bf..f701f2d52 100644 --- a/packages/hub/src/types/api/api-create-repo.ts +++ b/packages/hub/src/types/api/api-create-repo.ts @@ -1,4 +1,4 @@ -import type { SetRequired } from "type-fest"; +import type { SetRequired } from "../../vendor/type-fest/set-required"; import type { RepoType, SpaceHardwareFlavor, SpaceSdk } from "../public"; import type { ApiCommitFile } from "./api-commit"; 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/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..68e2f9ca9 --- /dev/null +++ b/packages/hub/src/vendor/type-fest/entry.ts @@ -0,0 +1,65 @@ +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; From d854ff83766761b710977e1089d2c1e89cd5c072 Mon Sep 17 00:00:00 2001 From: coyotte508 Date: Mon, 6 May 2024 17:05:22 +0200 Subject: [PATCH 04/14] =?UTF-8?q?=F0=9F=A9=B9=20Fix=20inference=20source?= =?UTF-8?q?=20file=20location?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- packages/inference/package.json | 4 ++-- packages/inference/tsconfig.json | 2 +- 2 files changed, 3 insertions(+), 3 deletions(-) diff --git a/packages/inference/package.json b/packages/inference/package.json index 0d1be0708..2e012d4f5 100644 --- a/packages/inference/package.json +++ b/packages/inference/package.json @@ -29,11 +29,11 @@ "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" }, diff --git a/packages/inference/tsconfig.json b/packages/inference/tsconfig.json index 88dd38c3d..4de007d35 100644 --- a/packages/inference/tsconfig.json +++ b/packages/inference/tsconfig.json @@ -13,6 +13,6 @@ "declarationMap": true, "outDir": "./dist" }, - "include": ["src", "test", "index.ts"], + "include": ["src", "test"], "exclude": ["dist"] } From dc6bc0b93b7d9d06ed5045f2a2ead7350e23df8a Mon Sep 17 00:00:00 2001 From: coyotte508 Date: Mon, 6 May 2024 17:10:06 +0200 Subject: [PATCH 05/14] =?UTF-8?q?=F0=9F=99=88=20add=20lint=20ignore=20file?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- packages/gguf/.eslintignore | 1 + 1 file changed, 1 insertion(+) create mode 100644 packages/gguf/.eslintignore 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 From bec02d30cb35871eb965849f01dbdf4b33116362 Mon Sep 17 00:00:00 2001 From: coyotte508 Date: Mon, 6 May 2024 17:29:56 +0200 Subject: [PATCH 06/14] =?UTF-8?q?=F0=9F=9A=A8=20prettier?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- packages/hub/src/vendor/type-fest/entry.ts | 15 +++++++++------ packages/hub/src/vendor/type-fest/set-required.ts | 13 ++++++------- 2 files changed, 15 insertions(+), 13 deletions(-) diff --git a/packages/hub/src/vendor/type-fest/entry.ts b/packages/hub/src/vendor/type-fest/entry.ts index 68e2f9ca9..ed3650c90 100644 --- a/packages/hub/src/vendor/type-fest/entry.ts +++ b/packages/hub/src/vendor/type-fest/entry.ts @@ -57,9 +57,12 @@ const setEntryNumber: Entry = [1, 1]; @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; +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/set-required.ts b/packages/hub/src/vendor/type-fest/set-required.ts index d25e6e0d8..8e4c6417a 100644 --- a/packages/hub/src/vendor/type-fest/set-required.ts +++ b/packages/hub/src/vendor/type-fest/set-required.ts @@ -1,5 +1,5 @@ -import type {Except} from './except'; -import type {Simplify} from './simplify'; +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. @@ -26,10 +26,9 @@ type SomeRequired = SetRequired; @category Object */ -export type SetRequired = - Simplify< +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> - >; + // Pick the keys that should be required from the base type and make them required. + Required> +>; From 6c932c4bd8af524153aef4c5ef6f490aee9bee29 Mon Sep 17 00:00:00 2001 From: coyotte508 Date: Mon, 6 May 2024 18:07:00 +0200 Subject: [PATCH 07/14] =?UTF-8?q?=F0=9F=91=BD=EF=B8=8F=20Fix=20tsconfig=20?= =?UTF-8?q?for=20widgets?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- packages/widgets/tsconfig.json | 4 +--- 1 file changed, 1 insertion(+), 3 deletions(-) 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 } } From 6930ddb7f7c9aa59bae25d0fbef09e2c3815bb82 Mon Sep 17 00:00:00 2001 From: coyotte508 Date: Mon, 6 May 2024 18:26:05 +0200 Subject: [PATCH 08/14] silence widgets error --- packages/widgets/vite.config.ts | 1 + 1 file changed, 1 insertion(+) 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", }, }), From fd0c0325de8233bc6e6aa67879b42a279c1c8ddd Mon Sep 17 00:00:00 2001 From: coyotte508 Date: Tue, 7 May 2024 13:00:42 +0200 Subject: [PATCH 09/14] =?UTF-8?q?=F0=9F=91=B7=20Split=20tests=20into=203?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .github/workflows/test.yml | 46 ++++++++++++++++++++++++++++++++++++++ 1 file changed, 46 insertions(+) diff --git a/.github/workflows/test.yml b/.github/workflows/test.yml index 99df0df10..934699bc3 100644 --- a/.github/workflows/test.yml +++ b/.github/workflows/test.yml @@ -42,11 +42,57 @@ jobs: env: HF_TOKEN: ${{ secrets.HF_TOKEN }} + browser-test: + 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-test: + 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 From cf6782f63d877ff0f5bc52901026f285378f9bab Mon Sep 17 00:00:00 2001 From: coyotte508 Date: Tue, 7 May 2024 13:02:17 +0200 Subject: [PATCH 10/14] =?UTF-8?q?=F0=9F=9A=9A=20Rename=20test=20jobs?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .github/workflows/test.yml | 6 +++--- 1 file changed, 3 insertions(+), 3 deletions(-) diff --git a/.github/workflows/test.yml b/.github/workflows/test.yml index 934699bc3..614ef5123 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,7 +42,7 @@ jobs: env: HF_TOKEN: ${{ secrets.HF_TOKEN }} - browser-test: + browser: runs-on: ubuntu-latest timeout-minutes: 10 @@ -78,7 +78,7 @@ jobs: env: HF_TOKEN: ${{ secrets.HF_TOKEN }} - e2e-test: + e2e: runs-on: ubuntu-latest timeout-minutes: 10 From 09b6c7af7640bc4e07179cd1580d665bf7657f2e Mon Sep 17 00:00:00 2001 From: coyotte508 Date: Tue, 7 May 2024 13:03:42 +0200 Subject: [PATCH 11/14] =?UTF-8?q?=F0=9F=91=B7=20Install=20tsup=20in=20e2e?= =?UTF-8?q?=20tests?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .github/workflows/test.yml | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/.github/workflows/test.yml b/.github/workflows/test.yml index 614ef5123..4e8ba4492 100644 --- a/.github/workflows/test.yml +++ b/.github/workflows/test.yml @@ -104,7 +104,7 @@ jobs: working-directory: e2e run: | sleep 3 - pnpm i --filter inference... --filter hub... --frozen-lockfile + pnpm i --filter . --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 From 75174d8f415a7fe8e6335697e9d0369d00d523f2 Mon Sep 17 00:00:00 2001 From: coyotte508 Date: Tue, 7 May 2024 13:27:41 +0200 Subject: [PATCH 12/14] =?UTF-8?q?=F0=9F=91=B7=20Fix=20E2E=20CI=3F?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .github/workflows/test.yml | 2 +- package.json | 2 ++ 2 files changed, 3 insertions(+), 1 deletion(-) diff --git a/.github/workflows/test.yml b/.github/workflows/test.yml index 4e8ba4492..f2f7f0ec5 100644 --- a/.github/workflows/test.yml +++ b/.github/workflows/test.yml @@ -104,7 +104,7 @@ jobs: working-directory: e2e run: | sleep 3 - pnpm i --filter . --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/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": { From 228f6561b758b8ff30e8103616febd9b4067fd4f Mon Sep 17 00:00:00 2001 From: coyotte508 Date: Tue, 7 May 2024 13:38:09 +0200 Subject: [PATCH 13/14] =?UTF-8?q?=E2=9C=85=20Fix=20E2E=3F!?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- e2e/.gitignore | 2 ++ packages/tasks/package.json | 2 +- 2 files changed, 3 insertions(+), 1 deletion(-) create mode 100644 e2e/.gitignore 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/packages/tasks/package.json b/packages/tasks/package.json index 2b77cb7c8..09a35824f 100644 --- a/packages/tasks/package.json +++ b/packages/tasks/package.json @@ -23,7 +23,7 @@ "lint:check": "eslint --ext .cjs,.ts .", "format": "prettier --write .", "format:check": "prettier --check .", - "prepublishOnly": "pnpm run inference-codegen && git diff --name-only --exit-code && pnpm run build", + "prepublishOnly": "pnpm run inference-codegen && git diff . --name-only --exit-code && pnpm run build", "build": "tsup src/index.ts --format cjs,esm --clean && tsc --emitDeclarationOnly --declaration", "prepare": "pnpm run build", "check": "tsc", From 752670eb34dc883bac3fa5753af70196305d49a0 Mon Sep 17 00:00:00 2001 From: coyotte508 Date: Tue, 7 May 2024 13:41:53 +0200 Subject: [PATCH 14/14] =?UTF-8?q?fixup!=20=E2=9C=85=20Fix=20E2E=3F!?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- packages/tasks/package.json | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/packages/tasks/package.json b/packages/tasks/package.json index 09a35824f..b8d8a4849 100644 --- a/packages/tasks/package.json +++ b/packages/tasks/package.json @@ -23,7 +23,7 @@ "lint:check": "eslint --ext .cjs,.ts .", "format": "prettier --write .", "format:check": "prettier --check .", - "prepublishOnly": "pnpm run inference-codegen && git diff . --name-only --exit-code && pnpm run build", + "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",