From 33789bec056b6409bd99cdf520db53d7bee62076 Mon Sep 17 00:00:00 2001 From: Daniel Roe Date: Mon, 9 Dec 2024 12:28:48 +0000 Subject: [PATCH 1/2] test: add additional `attw` test for built packages (#30206) --- .github/workflows/ci.yml | 3 + package.json | 2 + packages/kit/.attw.json | 3 + packages/kit/package.json | 3 +- packages/nuxt/.attw.json | 3 + packages/nuxt/package.json | 3 +- .../app/components/nuxt-route-announcer.ts | 2 +- packages/nuxt/src/app/composables/index.ts | 1 + packages/nuxt/src/app/index.ts | 2 +- packages/nuxt/src/app/nuxt.ts | 4 +- packages/nuxt/src/core/app.ts | 4 +- .../nuxt/src/core/plugins/plugin-metadata.ts | 3 +- packages/nuxt/src/core/runtime/nitro/error.ts | 2 +- .../nuxt/src/core/runtime/nitro/renderer.ts | 2 +- .../nuxt/src/pages/runtime/composables.ts | 2 +- .../nuxt/src/pages/runtime/plugins/router.ts | 3 +- packages/rspack/.attw.json | 3 + packages/rspack/package.json | 3 +- packages/schema/.attw.json | 5 + packages/schema/build.config.ts | 2 +- packages/schema/builder-env.d.ts | 2 +- packages/schema/package.json | 4 +- packages/schema/src/config/experimental.ts | 2 +- packages/vite/.attw.json | 3 + packages/vite/package.json | 3 +- packages/webpack/.attw.json | 3 + packages/webpack/package.json | 3 +- pnpm-lock.yaml | 211 ++++++++++++++++++ 28 files changed, 265 insertions(+), 21 deletions(-) create mode 100644 packages/kit/.attw.json create mode 100644 packages/nuxt/.attw.json create mode 100644 packages/rspack/.attw.json create mode 100644 packages/schema/.attw.json create mode 100644 packages/vite/.attw.json create mode 100644 packages/webpack/.attw.json diff --git a/.github/workflows/ci.yml b/.github/workflows/ci.yml index 5d211a26b113..1fa952b958a1 100644 --- a/.github/workflows/ci.yml +++ b/.github/workflows/ci.yml @@ -56,6 +56,9 @@ jobs: - name: Build run: pnpm build + - name: Check types + run: pnpm test:attw + - name: Cache dist uses: actions/upload-artifact@b4b15b8c7c6ac21ea08fcf65892d2ee8f75cf882 # v4.4.3 with: diff --git a/package.json b/package.json index d15396d121c8..70542209efcb 100644 --- a/package.json +++ b/package.json @@ -30,6 +30,7 @@ "test:runtime": "vitest -c vitest.nuxt.config.ts", "test:types": "pnpm --filter './test/fixtures/**' test:types", "test:unit": "vitest run packages/", + "test:attw": "pnpm --filter './packages/**' test:attw", "typecheck": "tsc --noEmit", "typecheck:docs": "DOCS_TYPECHECK=true pnpm nuxi prepare && nuxt-content-twoslash verify --content-dir docs --languages html" }, @@ -67,6 +68,7 @@ "vue": "3.5.13" }, "devDependencies": { + "@arethetypeswrong/cli": "0.17.1", "@nuxt/eslint-config": "0.7.2", "@nuxt/kit": "workspace:*", "@nuxt/rspack-builder": "workspace:*", diff --git a/packages/kit/.attw.json b/packages/kit/.attw.json new file mode 100644 index 000000000000..ac2579855eb0 --- /dev/null +++ b/packages/kit/.attw.json @@ -0,0 +1,3 @@ +{ + "ignoreRules": ["cjs-resolves-to-esm"] +} diff --git a/packages/kit/package.json b/packages/kit/package.json index 1889e82a4299..bd91d7c256dd 100644 --- a/packages/kit/package.json +++ b/packages/kit/package.json @@ -23,7 +23,8 @@ "dist" ], "scripts": { - "prepack": "unbuild" + "prepack": "unbuild", + "test:attw": "attw --pack" }, "dependencies": { "@nuxt/schema": "workspace:*", diff --git a/packages/nuxt/.attw.json b/packages/nuxt/.attw.json new file mode 100644 index 000000000000..80f18ecbfdff --- /dev/null +++ b/packages/nuxt/.attw.json @@ -0,0 +1,3 @@ +{ + "ignoreRules": ["cjs-resolves-to-esm", "false-esm"] +} diff --git a/packages/nuxt/package.json b/packages/nuxt/package.json index f994e3b5addd..00925b81ac57 100644 --- a/packages/nuxt/package.json +++ b/packages/nuxt/package.json @@ -64,7 +64,8 @@ "schema.*" ], "scripts": { - "prepack": "unbuild" + "prepack": "unbuild", + "test:attw": "attw --pack" }, "dependencies": { "@nuxt/devalue": "^2.0.2", diff --git a/packages/nuxt/src/app/components/nuxt-route-announcer.ts b/packages/nuxt/src/app/components/nuxt-route-announcer.ts index 035e9e9e502e..389ae3be0cd0 100644 --- a/packages/nuxt/src/app/components/nuxt-route-announcer.ts +++ b/packages/nuxt/src/app/components/nuxt-route-announcer.ts @@ -1,5 +1,5 @@ import { defineComponent, h } from 'vue' -import type { Politeness } from '#app/composables/route-announcer' +import type { Politeness } from 'nuxt/app' import { useRouteAnnouncer } from '#app/composables/route-announcer' export default defineComponent({ diff --git a/packages/nuxt/src/app/composables/index.ts b/packages/nuxt/src/app/composables/index.ts index 7d5e0e317f79..c837ba8dfbef 100644 --- a/packages/nuxt/src/app/composables/index.ts +++ b/packages/nuxt/src/app/composables/index.ts @@ -38,4 +38,5 @@ export { useRequestURL } from './url' export { usePreviewMode } from './preview' export { useId } from './id' export { useRouteAnnouncer } from './route-announcer' +export type { Politeness } from './route-announcer' export { useRuntimeHook } from './runtime-hook' diff --git a/packages/nuxt/src/app/index.ts b/packages/nuxt/src/app/index.ts index c530599b2827..9935ab9f75d1 100644 --- a/packages/nuxt/src/app/index.ts +++ b/packages/nuxt/src/app/index.ts @@ -2,7 +2,7 @@ export { applyPlugin, applyPlugins, callWithNuxt, createNuxtApp, defineAppConfig export type { CreateOptions, NuxtApp, NuxtPayload, NuxtPluginIndicator, NuxtSSRContext, ObjectPlugin, Plugin, PluginEnvContext, PluginMeta, ResolvedPluginMeta, RuntimeNuxtHooks } from './nuxt' export { defineNuxtComponent, useAsyncData, useLazyAsyncData, useNuxtData, refreshNuxtData, clearNuxtData, useHydration, callOnce, useState, clearNuxtState, clearError, createError, isNuxtError, showError, useError, useFetch, useLazyFetch, useCookie, refreshCookie, onPrehydrate, prerenderRoutes, useRequestHeaders, useRequestEvent, useRequestFetch, setResponseStatus, useResponseHeader, onNuxtReady, abortNavigation, addRouteMiddleware, defineNuxtRouteMiddleware, onBeforeRouteLeave, onBeforeRouteUpdate, setPageLayout, navigateTo, useRoute, useRouter, preloadComponents, prefetchComponents, preloadRouteComponents, isPrerendered, loadPayload, preloadPayload, definePayloadReducer, definePayloadReviver, getAppManifest, getRouteRules, reloadNuxtApp, useRequestURL, usePreviewMode, useId, useRouteAnnouncer, useHead, useSeoMeta, useServerSeoMeta, useRuntimeHook } from './composables/index' -export type { AddRouteMiddlewareOptions, AsyncData, AsyncDataOptions, AsyncDataRequestStatus, CookieOptions, CookieRef, FetchResult, NuxtAppManifest, NuxtAppManifestMeta, NuxtError, ReloadNuxtAppOptions, RouteMiddleware, UseFetchOptions } from './composables/index' +export type { AddRouteMiddlewareOptions, AsyncData, AsyncDataOptions, AsyncDataRequestStatus, CookieOptions, CookieRef, FetchResult, NuxtAppManifest, NuxtAppManifestMeta, NuxtError, Politeness, ReloadNuxtAppOptions, RouteMiddleware, UseFetchOptions } from './composables/index' export { defineNuxtLink } from './components/index' export type { NuxtLinkOptions, NuxtLinkProps } from './components/index' diff --git a/packages/nuxt/src/app/nuxt.ts b/packages/nuxt/src/app/nuxt.ts index cea95b4c3039..f127c9c94f14 100644 --- a/packages/nuxt/src/app/nuxt.ts +++ b/packages/nuxt/src/app/nuxt.ts @@ -11,6 +11,8 @@ import type { RenderResponse } from 'nitro/types' import type { LogObject } from 'consola' import type { MergeHead, VueHeadClient } from '@unhead/vue' +import type { NuxtAppLiterals } from 'nuxt/app' + import type { NuxtIslandContext } from '../app/types' import type { RouteMiddleware } from '../app/composables/router' import type { NuxtError } from '../app/composables/error' @@ -22,8 +24,6 @@ import type { RouteAnnouncer } from '../app/composables/route-announcer' // @ts-expect-error virtual file import { appId, chunkErrorEvent, multiApp } from '#build/nuxt.config.mjs' -import type { NuxtAppLiterals } from '#app' - function getNuxtAppCtx (id = appId || 'nuxt-app') { return getContext(id, { asyncContext: !!__NUXT_ASYNC_CONTEXT__ && import.meta.server, diff --git a/packages/nuxt/src/core/app.ts b/packages/nuxt/src/core/app.ts index bc1ff0cb66b0..ddfa14e39059 100644 --- a/packages/nuxt/src/core/app.ts +++ b/packages/nuxt/src/core/app.ts @@ -4,12 +4,12 @@ import { defu } from 'defu' import { findPath, logger, normalizePlugin, normalizeTemplate, resolveAlias, resolveFiles, resolvePath } from '@nuxt/kit' import type { Nuxt, NuxtApp, NuxtPlugin, NuxtTemplate, ResolvedNuxtTemplate } from 'nuxt/schema' +import type { PluginMeta } from 'nuxt/app' + import * as defaultTemplates from './templates' import { getNameFromPath, hasSuffix, uniqueBy } from './utils' import { extractMetadata, orderMap } from './plugins/plugin-metadata' -import type { PluginMeta } from '#app' - export function createApp (nuxt: Nuxt, options: Partial = {}): NuxtApp { return defu(options, { dir: nuxt.options.srcDir, diff --git a/packages/nuxt/src/core/plugins/plugin-metadata.ts b/packages/nuxt/src/core/plugins/plugin-metadata.ts index 3b0b080ac432..c6db582eb4ed 100644 --- a/packages/nuxt/src/core/plugins/plugin-metadata.ts +++ b/packages/nuxt/src/core/plugins/plugin-metadata.ts @@ -7,11 +7,10 @@ import { createUnplugin } from 'unplugin' import MagicString from 'magic-string' import { normalize } from 'pathe' import { logger } from '@nuxt/kit' +import type { ObjectPlugin, PluginMeta } from 'nuxt/app' import { parseAndWalk, withLocations } from '../../core/utils/parse' -import type { ObjectPlugin, PluginMeta } from '#app' - const internalOrderMap = { // -50: pre-all (nuxt) 'nuxt-pre-all': -50, diff --git a/packages/nuxt/src/core/runtime/nitro/error.ts b/packages/nuxt/src/core/runtime/nitro/error.ts index d2899e4608db..25f6cca69dca 100644 --- a/packages/nuxt/src/core/runtime/nitro/error.ts +++ b/packages/nuxt/src/core/runtime/nitro/error.ts @@ -3,7 +3,7 @@ import type { NitroErrorHandler } from 'nitro/types' import type { H3Error, H3Event } from 'h3' import { getRequestHeader, getRequestHeaders, send, setResponseHeader, setResponseStatus } from 'h3' import { useNitroApp, useRuntimeConfig } from 'nitro/runtime' -import type { NuxtPayload } from '#app' +import type { NuxtPayload } from 'nuxt/app' export default async function errorhandler (error: H3Error, event) { // Parse and normalize error diff --git a/packages/nuxt/src/core/runtime/nitro/renderer.ts b/packages/nuxt/src/core/runtime/nitro/renderer.ts index 72835866270a..89de122e2ff9 100644 --- a/packages/nuxt/src/core/runtime/nitro/renderer.ts +++ b/packages/nuxt/src/core/runtime/nitro/renderer.ts @@ -22,13 +22,13 @@ import type { Link, Script, Style } from '@unhead/vue' import { createServerHead, resolveUnrefHeadInput } from '@unhead/vue' import { defineRenderHandler, getRouteRules, useNitroApp, useRuntimeConfig, useStorage } from 'nitro/runtime' +import type { NuxtPayload, NuxtSSRContext } from 'nuxt/app' // @ts-expect-error virtual file import unheadPlugins from '#internal/unhead-plugins.mjs' // @ts-expect-error virtual file import { renderSSRHeadOptions } from '#internal/unhead.config.mjs' -import type { NuxtPayload, NuxtSSRContext } from '#app' // @ts-expect-error virtual file import { appHead, appId, appRootAttrs, appRootTag, appTeleportAttrs, appTeleportTag, componentIslands, appManifest as isAppManifestEnabled, multiApp } from '#internal/nuxt.config.mjs' // @ts-expect-error virtual file diff --git a/packages/nuxt/src/pages/runtime/composables.ts b/packages/nuxt/src/pages/runtime/composables.ts index b752a101d49e..8b281e58bd2d 100644 --- a/packages/nuxt/src/pages/runtime/composables.ts +++ b/packages/nuxt/src/pages/runtime/composables.ts @@ -3,8 +3,8 @@ import { getCurrentInstance } from 'vue' import type { RouteLocationNormalized, RouteLocationNormalizedLoaded, RouteRecordRaw, RouteRecordRedirectOption } from 'vue-router' import { useRoute } from 'vue-router' import type { NitroRouteConfig } from 'nitro/types' +import type { NuxtError } from 'nuxt/app' import { useNuxtApp } from '#app/nuxt' -import type { NuxtError } from '#app' export interface PageMeta { [key: string]: unknown diff --git a/packages/nuxt/src/pages/runtime/plugins/router.ts b/packages/nuxt/src/pages/runtime/plugins/router.ts index 0bf42801ef68..894d915a5dab 100644 --- a/packages/nuxt/src/pages/runtime/plugins/router.ts +++ b/packages/nuxt/src/pages/runtime/plugins/router.ts @@ -5,10 +5,11 @@ import { START_LOCATION, createMemoryHistory, createRouter, createWebHashHistory import { createError } from 'h3' import { isEqual, withoutBase } from 'ufo' +import type { Plugin, RouteMiddleware } from 'nuxt/app' import type { PageMeta } from '../composables' import { toArray } from '../utils' -import type { Plugin, RouteMiddleware } from '#app' + import { getRouteRules } from '#app/composables/manifest' import { defineNuxtPlugin, useRuntimeConfig } from '#app/nuxt' import { clearError, showError, useError } from '#app/composables/error' diff --git a/packages/rspack/.attw.json b/packages/rspack/.attw.json new file mode 100644 index 000000000000..ac2579855eb0 --- /dev/null +++ b/packages/rspack/.attw.json @@ -0,0 +1,3 @@ +{ + "ignoreRules": ["cjs-resolves-to-esm"] +} diff --git a/packages/rspack/package.json b/packages/rspack/package.json index 15062d250dfc..9c839450975b 100644 --- a/packages/rspack/package.json +++ b/packages/rspack/package.json @@ -26,7 +26,8 @@ "builder.mjs" ], "scripts": { - "prepack": "unbuild" + "prepack": "unbuild", + "test:attw": "attw --pack" }, "dependencies": { "@nuxt/friendly-errors-webpack-plugin": "^2.6.0", diff --git a/packages/schema/.attw.json b/packages/schema/.attw.json new file mode 100644 index 000000000000..7aa79ea413cf --- /dev/null +++ b/packages/schema/.attw.json @@ -0,0 +1,5 @@ +{ + "ignoreRules": [ + "cjs-resolves-to-esm" + ] +} diff --git a/packages/schema/build.config.ts b/packages/schema/build.config.ts index a78a96277329..4658f5a4ff1c 100644 --- a/packages/schema/build.config.ts +++ b/packages/schema/build.config.ts @@ -22,7 +22,7 @@ export default defineBuildConfig({ ], externals: [ // Type imports - '#app/components/nuxt-link', + 'nuxt/app', 'cssnano', 'autoprefixer', 'ofetch', diff --git a/packages/schema/builder-env.d.ts b/packages/schema/builder-env.d.ts index 3fc7325ea7bd..ebfb9fce8ee3 100644 --- a/packages/schema/builder-env.d.ts +++ b/packages/schema/builder-env.d.ts @@ -1 +1 @@ -export * from './dist/env' +export * from './dist/builder-env' diff --git a/packages/schema/package.json b/packages/schema/package.json index bb6d76f72ebe..64367cc7f8b8 100644 --- a/packages/schema/package.json +++ b/packages/schema/package.json @@ -28,10 +28,12 @@ "files": [ "dist", "schema", + "builder-env.d.ts", "env.d.ts" ], "scripts": { - "prepack": "unbuild" + "prepack": "unbuild", + "test:attw": "attw --pack" }, "devDependencies": { "@types/file-loader": "5.0.4", diff --git a/packages/schema/src/config/experimental.ts b/packages/schema/src/config/experimental.ts index 726ee551af80..399b491a151a 100644 --- a/packages/schema/src/config/experimental.ts +++ b/packages/schema/src/config/experimental.ts @@ -360,7 +360,7 @@ export default defineUntypedSchema({ * `app/` directory. */ defaults: { - /** @type {typeof import('#app/components/nuxt-link')['NuxtLinkOptions']} */ + /** @type {typeof import('nuxt/app')['NuxtLinkOptions']} */ nuxtLink: { componentName: 'NuxtLink', prefetch: true, diff --git a/packages/vite/.attw.json b/packages/vite/.attw.json new file mode 100644 index 000000000000..ac2579855eb0 --- /dev/null +++ b/packages/vite/.attw.json @@ -0,0 +1,3 @@ +{ + "ignoreRules": ["cjs-resolves-to-esm"] +} diff --git a/packages/vite/package.json b/packages/vite/package.json index 341798e9f92a..c08b8229335f 100644 --- a/packages/vite/package.json +++ b/packages/vite/package.json @@ -21,7 +21,8 @@ "dist" ], "scripts": { - "prepack": "unbuild" + "prepack": "unbuild", + "test:attw": "attw --pack" }, "devDependencies": { "@nuxt/schema": "workspace:*", diff --git a/packages/webpack/.attw.json b/packages/webpack/.attw.json new file mode 100644 index 000000000000..ac2579855eb0 --- /dev/null +++ b/packages/webpack/.attw.json @@ -0,0 +1,3 @@ +{ + "ignoreRules": ["cjs-resolves-to-esm"] +} diff --git a/packages/webpack/package.json b/packages/webpack/package.json index dd33f09a17fc..0fc9693bf908 100644 --- a/packages/webpack/package.json +++ b/packages/webpack/package.json @@ -26,7 +26,8 @@ "builder.mjs" ], "scripts": { - "prepack": "unbuild" + "prepack": "unbuild", + "test:attw": "attw --pack" }, "dependencies": { "@nuxt/friendly-errors-webpack-plugin": "^2.6.0", diff --git a/pnpm-lock.yaml b/pnpm-lock.yaml index 4489d2336feb..75062c73df39 100644 --- a/pnpm-lock.yaml +++ b/pnpm-lock.yaml @@ -41,6 +41,9 @@ importers: .: devDependencies: + '@arethetypeswrong/cli': + specifier: 0.17.1 + version: 0.17.1 '@nuxt/eslint-config': specifier: 0.7.2 version: 0.7.2(@vue/compiler-sfc@3.5.13)(eslint@9.16.0(jiti@2.4.1))(typescript@5.6.3) @@ -1160,6 +1163,9 @@ packages: resolution: {integrity: sha512-30iZtAPgz+LTIYoeivqYo853f02jBYSd5uGnGpkFV0M3xOt9aN73erkgYAmZU43x4VfqcnLxW9Kpg3R5LC4YYw==} engines: {node: '>=6.0.0'} + '@andrewbranch/untar.js@1.0.3': + resolution: {integrity: sha512-Jh15/qVmrLGhkKJBdXlK1+9tY4lZruYjsgkDFj08ZmDiWVBLJcqkok7Z0/R0In+i1rScBpJlSvrTS2Lm41Pbnw==} + '@antfu/install-pkg@0.4.1': resolution: {integrity: sha512-T7yB5QNG29afhWVkVq7XeIMBa5U/vs9mX69YqayXypPRmYzUmzwnYltplHmPtZ4HPCn+sQKeXW8I47wCbuBOjw==} @@ -1170,6 +1176,15 @@ packages: resolution: {integrity: sha512-pRrmXMCwnmrkS3MLgAIW5dXRzeTv6GLjkjb4HmxNnvAKXN1Nfzp4KmGADBQvlVUcqi+a5D+hfGDLLnd5NnYxog==} engines: {node: '>= 16'} + '@arethetypeswrong/cli@0.17.1': + resolution: {integrity: sha512-WNKTcC7lqWmbRWWku3Xz0hl7zj9szoGzx7gcGaZPxszKcMPiRnKsiLbxMpf1FzA6myIjE1yalqxNCJ0UkCWTXQ==} + engines: {node: '>=18'} + hasBin: true + + '@arethetypeswrong/core@0.17.1': + resolution: {integrity: sha512-NgEuyO/D79q2K6lVoSLmRX2YzKNlh2LHU+no3AVkpY4gA20zEhp129KUV1W6jMnbmpRm3xAxF+v3myZ/eFixnA==} + engines: {node: '>=18'} + '@babel/code-frame@7.26.2': resolution: {integrity: sha512-RJlIHRueQgwWitWgF8OdFYGZX328Ax5BCemNGlqHfplnRT9ESi8JkFlvaVYbS+UubVY6dpv87Fs2u5M29iNFVQ==} engines: {node: '>=6.9.0'} @@ -1327,6 +1342,10 @@ packages: resolution: {integrity: sha512-YLPHc8yASwjNkmcDMQMY35yiWjoKAKnhUbPRszBRS0YgH+IXtsMp61j+yTcnCE3oO2DgP0U3iejLC8FTtKDC8Q==} engines: {node: '>=16.13'} + '@colors/colors@1.5.0': + resolution: {integrity: sha512-ooWCrlZP11i8GImSjTHYHLkvFDP48nS4+204nGb1RiX/WXYHmJA2III9/e2DWVabCESdW7hBAEzHRqUn9OUVvQ==} + engines: {node: '>=0.1.90'} + '@discoveryjs/json-ext@0.5.7': resolution: {integrity: sha512-dBVuXR082gk3jsFp7Rd/JI4kytwGHecnCoTtXFb7DB6CNHp4rg5k1bhg0nWdLGLnOV71lmDzGQaLMy8iPLY0pw==} engines: {node: '>=10.0.0'} @@ -3282,6 +3301,10 @@ packages: resolution: {integrity: sha512-gKXj5ALrKWQLsYG9jlTRmR/xKluxHV+Z9QEwNIgCfM1/uwPMCuzVVnh5mwTd+OuBZcwSIMbqssNWRm1lE51QaQ==} engines: {node: '>=8'} + ansi-escapes@7.0.0: + resolution: {integrity: sha512-GdYO7a61mR0fOlAsvC9/rIHf7L96sBc6dEWzeOu+KAea5bZyQRPIpojrVoI4AXGJS/ycu/fBTdLrUkA4ODrvjw==} + engines: {node: '>=18'} + ansi-html-community@0.0.8: resolution: {integrity: sha512-1APHAyr3+PCamwNw3bXCPp4HFLONZt/yIH0sZp0/469KWNTEy+qN5jQ3GVX6DMZ1UXAi34yVwtTeaG/HpBuuzw==} engines: {'0': node >= 0.8.0} @@ -3315,6 +3338,9 @@ packages: resolution: {integrity: sha512-cFthbBlt+Oi0i9Pv/j6YdVWJh54CtjGACaMPCIrEV4Ha7HWsIjXDwseYV79TIL0B4+KfSwD5S70PeQDkPUd1rA==} engines: {node: '>=15'} + any-promise@1.3.0: + resolution: {integrity: sha512-7UvmKalWRt1wgjL1RrGxoSJW/0QZFIegpeGvZG9kjp8vrRu55XTHbwnqq2GpXm9uLbcuhxm3IqX9OB4MZR1b2A==} + anymatch@3.1.3: resolution: {integrity: sha512-KMReFUr0B4t+D+OBkjR3KYqvocp2XaSzO55UcB6mgQMd3KbcE+mWTyvVV7D/zsdEbNnV6acZUutkiHQXvTr1Rw==} engines: {node: '>= 8'} @@ -3581,6 +3607,9 @@ packages: citty@0.1.6: resolution: {integrity: sha512-tskPPKEs8D2KPafUypv2gxwJP8h/OaJmC82QQGGDQcHvXX43xF2VDACcJVmZ0EuSxkpO9Kc4MlrA3q0+FG58AQ==} + cjs-module-lexer@1.4.1: + resolution: {integrity: sha512-cuSVIHi9/9E/+821Qjdvngor+xpnlwnuwIyZOaLmHBVdXL+gP+I6QQB9VkO7RI77YIcTV+S1W9AreJ5eN63JBA==} + clean-regexp@1.0.0: resolution: {integrity: sha512-GfisEZEJvzKrmGWkvfhgzcz/BllN1USeqD2V6tg14OAOgaCD2Z/PUEuxnAZ/nPvmaHRG7a8y77p1T/IRQ4D1Hw==} engines: {node: '>=4'} @@ -3592,10 +3621,22 @@ packages: clear@0.1.0: resolution: {integrity: sha512-qMjRnoL+JDPJHeLePZJuao6+8orzHMGP04A8CdwCNsKhRbOnKRjefxONR7bwILT3MHecxKBjHkKL/tkZ8r4Uzw==} + cli-highlight@2.1.11: + resolution: {integrity: sha512-9KDcoEVwyUXrjcJNvHD0NFc/hiwe/WPVYIleQh2O1N2Zro5gWJZ/K+3DGn8w8P/F6FxOgzyC5bxDyHIgCSPhGg==} + engines: {node: '>=8.0.0', npm: '>=5.0.0'} + hasBin: true + + cli-table3@0.6.5: + resolution: {integrity: sha512-+W/5efTR7y5HRD7gACw9yQjqMVvEMLBHmboM/kPWam+H+Hmyrgjh6YncVKK122YZkXrLudzTuAukUw9FnMf7IQ==} + engines: {node: 10.* || >= 12.*} + clipboardy@4.0.0: resolution: {integrity: sha512-5mOlNS0mhX0707P2I0aZ2V/cmHUEO/fL7VFLqszkhUsxt7RwnmrInf/eEQKlf5GzvYeHIjT+Ov1HRfNmymlG0w==} engines: {node: '>=18'} + cliui@7.0.4: + resolution: {integrity: sha512-OcRE68cOsVMXp1Yvonl/fzkQOyjLSu/8bhPDfQt0e0/Eb283TKP20Fs2MqoPsr9SwA595rRCA+QMzYc9nBP+JQ==} + cliui@8.0.1: resolution: {integrity: sha512-BSeNnyus75C4//NQ9gQt1/csTXyo/8Sb+afLAkzAptFuMsod9HFokGNudZpi/oQV73hnVK+sR+5PVRMd+Dr7YQ==} engines: {node: '>=12'} @@ -4105,6 +4146,10 @@ packages: resolution: {integrity: sha512-+h1lkLKhZMTYjog1VEpJNG7NZJWcuc2DDk/qsqSTRRCOXiLjeQ1d1/udrUGhqMxUgAlwKNZ0cf2uqan5GLuS2A==} engines: {node: '>=6'} + environment@1.1.0: + resolution: {integrity: sha512-xUtoPkMggbz0MPyPiIWr1Kp4aeWJjDZ6SMvURhimjdZgsRuDplF5/s9hcgGhyXMhs+6vpnuoiZ2kFiu3FMnS8Q==} + engines: {node: '>=18'} + errno@0.1.8: resolution: {integrity: sha512-dJ6oBr5SQ1VSd9qkk7ByRgb/1SH4JZjCHSW/mr63/QcXO9zLVxvJ6Oy13nio03rxpSnVDDjFor75SjVeZWPW/A==} hasBin: true @@ -4370,6 +4415,9 @@ packages: picomatch: optional: true + fflate@0.8.2: + resolution: {integrity: sha512-cPJU47OaAoCbg0pBvzsgpTPhmhqI5eJjh/JIu8tPj5q+T7iLvW/JAYUqmE7KOB4R1ZyEhzBaIQpQpardBF5z8A==} + file-entry-cache@8.0.0: resolution: {integrity: sha512-XXTUwCvisa5oacNGRP9SfNtYBNAMi+RPwBFmblZEF7N7swHYQS6/Zfk7SRwx4D5j3CH211YNRco1DEMNVfZCnQ==} engines: {node: '>=16.0.0'} @@ -4669,6 +4717,9 @@ packages: resolution: {integrity: sha512-F/1DnUGPopORZi0ni+CvrCgHQ5FyEAHRLSApuYWMmrbSwoN2Mn/7k+Gl38gJnR7yyDZk6WLXwiGod1JOWNDKGw==} hasBin: true + highlight.js@10.7.3: + resolution: {integrity: sha512-tzcUFauisWKNHaRkN4Wjl/ZA07gENAjFl3J/c480dprkGTg5EQstgaNFqBfUqCq54kZRIEcreTsAgF/m2quD7A==} + hookable@5.5.3: resolution: {integrity: sha512-Yc+BQe8SvoXH1643Qez1zqLRmbA5rCL+sSmk6TVos0LWVfNIB7PGncdlId77WzLGSIB5KaWgTaNTs2lNVEI6VQ==} @@ -5341,6 +5392,17 @@ packages: resolution: {integrity: sha512-s73fU2CQN7WCgjhaQUQ8wYESQNzGRNOKDd+3xgVqu8kuTEhmwepd/mxOv1LR2oV046ONrTLBFsM7IoKWNvmy5g==} engines: {node: '>=18'} + marked-terminal@7.2.1: + resolution: {integrity: sha512-rQ1MoMFXZICWNsKMiiHwP/Z+92PLKskTPXj+e7uwXmuMPkNn7iTqC+IvDekVm1MPeC9wYQeLxeFaOvudRR/XbQ==} + engines: {node: '>=16.0.0'} + peerDependencies: + marked: '>=1 <15' + + marked@9.1.6: + resolution: {integrity: sha512-jcByLnIFkd5gSXZmjNvS1TlmRhCXZjIzHYlaGkPlLIekG55JDR2Z4va9tZwCiP+/RDERiNhMOFu01xd6O5ct1Q==} + engines: {node: '>= 16'} + hasBin: true + mdast-util-find-and-replace@3.0.1: resolution: {integrity: sha512-SG21kZHGC3XRTSUhtofZkBzZTJNM5ecCi0SK2IMKmSXR8vO3peL+kb1O0z7Zl83jKtutG4k5Wv/W7V3/YHvzPA==} @@ -5618,6 +5680,9 @@ packages: muggle-string@0.4.1: resolution: {integrity: sha512-VNTrAak/KhO2i8dqqnqnAHOa3cYBwXEZe9h+D5h/1ZqFSTEFHdM65lR7RoIqq3tBBYavsOXV84NoHXZ0AkPyqQ==} + mz@2.7.0: + resolution: {integrity: sha512-z81GNO7nnYMEhrGh9LeymoE4+Yr0Wn5McHIZMK5cfQCl+NDX08sCZgUc9/6MHni9IWuFLm1Z3HTCXu2z9fN62Q==} + nanoid@3.3.7: resolution: {integrity: sha512-eSRppjcPIatRIMC1U6UngP8XFcz8MQWGQdt1MTBQ7NaAmvXDfvNxbvWV3x2y6CdEUciCSsDHDQZbhYaB8QEo2g==} engines: {node: ^10 || ^12 || ^13.7 || ^14 || >=15.0.1} @@ -5881,6 +5946,15 @@ packages: parse-url@8.1.0: resolution: {integrity: sha512-xDvOoLU5XRrcOZvnI6b8zA6n9O9ejNk/GExuz1yBuWUGn9KA97GI6HTs6u02wKara1CeVmZhH+0TZFdWScR89w==} + parse5-htmlparser2-tree-adapter@6.0.1: + resolution: {integrity: sha512-qPuWvbLgvDGilKc5BoicRovlT4MtYT6JfJyBOMDsKoiT+GiuP5qyrPCnR9HcPECIJJmZh5jRndyNThnhhb/vlA==} + + parse5@5.1.1: + resolution: {integrity: sha512-ugq4DFI0Ptb+WWjAdOK16+u/nHfiIrcE+sh8kZMaM0WllQKLI9rOUq6c2b7cwPkXdzfQESqvoqK6ug7U/Yyzug==} + + parse5@6.0.1: + resolution: {integrity: sha512-Ofn/CTFzRGTTxwpNEs9PP93gXShHcTq255nzRYSKe8AkVpZY7e1fpmTfOyoIvjP5HG7Z2ZM7VS9PPhQGW2pOpw==} + parse5@7.2.1: resolution: {integrity: sha512-BuBYQYlv1ckiPdQi/ohiivi9Sagc9JG+Ozs0r7b/0iK3sKmrb0b9FdWdBbOdx6hBCM/F9Ir82ofnBhtZOjCRPQ==} @@ -6869,6 +6943,10 @@ packages: resolution: {integrity: sha512-VL+lNrEoIXww1coLPOmiEmK/0sGigko5COxI09KzHc2VJXJsQ37UaQ+8quuxjDeA7+KnLGTWRyOXSLLR2Wb4jw==} engines: {node: '>=12'} + supports-hyperlinks@3.1.0: + resolution: {integrity: sha512-2rn0BZ+/f7puLOHZm1HOJfwBggfaHXUpPUSSG/SWM4TWp5KCfmNYwnC3hruy2rZlMnmWZ+QAGpZfchu3f3695A==} + engines: {node: '>=14.18'} + supports-preserve-symlinks-flag@1.0.0: resolution: {integrity: sha512-ot0WnXS9fgdkgIcePe6RHNk1WA8+muPa6cSjeR3V8K27q9BB1rTE3R1p7Hv0z1ZyAc8s6Vvv8DIyWf681MAt0w==} engines: {node: '>= 0.4'} @@ -6935,6 +7013,13 @@ packages: text-decoder@1.1.1: resolution: {integrity: sha512-8zll7REEv4GDD3x4/0pW+ppIxSNs7H1J10IKFZsuOMscumCdM2a+toDGLPA3T+1+fLBql4zbt5z83GEQGGV5VA==} + thenify-all@1.6.0: + resolution: {integrity: sha512-RNxQH/qI8/t3thXJDwcstUO4zeqo64+Uy/+sNVRBx4Xn2OX+OZ9oP+iJnNFqplFra2ZUVeKCSa2oVWi3T4uVmA==} + engines: {node: '>=0.8'} + + thenify@3.3.1: + resolution: {integrity: sha512-RVZSIV5IG10Hk3enotrhvz0T9em6cyHBLkH/YAZuKqd8hRkKhSfCGIcP2KUY0EPxndzANBmNllzWPwak+bheSw==} + thingies@1.21.0: resolution: {integrity: sha512-hsqsJsFMsV+aD4s3CWKk85ep/3I9XzYV/IXaSouJMYIoDlgyi11cBhsqYe9/geRfB0YIikBQg6raRaM+nIMP9g==} engines: {node: '>=10.18'} @@ -7289,6 +7374,10 @@ packages: validate-npm-package-license@3.0.4: resolution: {integrity: sha512-DpKm2Ui/xN7/HQKCtpZxoRWBhZ9Z0kqtygG8XCgNQ8ZlDnxuQmWhj566j8fN4Cu3/JmbhsDo7fcAJq4s9h27Ew==} + validate-npm-package-name@5.0.1: + resolution: {integrity: sha512-OljLrQ9SQdOUqTaQxqL5dEfZWrXExyyWsozYlAWFawPVNuD83igl7uJD2RTkNMbniIYgt8l81eCJGIdQF7avLQ==} + engines: {node: ^14.17.0 || ^16.13.0 || >=18.0.0} + version-guard@1.1.3: resolution: {integrity: sha512-JwPr6erhX53EWH/HCSzfy1tTFrtPXUe927wdM1jqBBeYp1OM+qPHjWbsvv6pIBduqdgxxS+ScfG7S28pzyr2DQ==} engines: {node: '>=0.10.48'} @@ -7734,10 +7823,18 @@ packages: engines: {node: '>= 14'} hasBin: true + yargs-parser@20.2.9: + resolution: {integrity: sha512-y11nGElTIV+CT3Zv9t7VKl+Q3hTQoT9a1Qzezhhl6Rp21gJ/IVTW7Z3y9EWXhuUBC2Shnf+DX0antecpAwSP8w==} + engines: {node: '>=10'} + yargs-parser@21.1.1: resolution: {integrity: sha512-tVpsJW7DdjecAiFpbIB1e3qxIQsE6NoPc5/eTdrbbIC4h0LVsWhnoa3g+m2HclBIujHzsxZ4VJVA+GUuc2/LBw==} engines: {node: '>=12'} + yargs@16.2.0: + resolution: {integrity: sha512-D1mvvtDG0L5ft/jGWkLpG1+m0eQxOfaBvTNELraWj22wSVUMWxZUvYgJYcKh6jGGIkJFhH4IZPQhR4TKpc8mBw==} + engines: {node: '>=10'} + yargs@17.7.2: resolution: {integrity: sha512-7dSzzRQ++CKnNI/krKnYRV7JKKPUXMEh61soaHKg9mrWEhzFWhFnxPxGl+69cD1Ou63C13NUPCnmIcrvqCuM6w==} engines: {node: '>=12'} @@ -7776,6 +7873,8 @@ snapshots: '@jridgewell/gen-mapping': 0.3.5 '@jridgewell/trace-mapping': 0.3.25 + '@andrewbranch/untar.js@1.0.3': {} + '@antfu/install-pkg@0.4.1': dependencies: package-manager-detector: 0.2.0 @@ -7789,6 +7888,26 @@ snapshots: '@types/json-schema': 7.0.15 js-yaml: 4.1.0 + '@arethetypeswrong/cli@0.17.1': + dependencies: + '@arethetypeswrong/core': 0.17.1 + chalk: 4.1.2 + cli-table3: 0.6.5 + commander: 10.0.1 + marked: 9.1.6 + marked-terminal: 7.2.1(marked@9.1.6) + semver: 7.6.3 + + '@arethetypeswrong/core@0.17.1': + dependencies: + '@andrewbranch/untar.js': 1.0.3 + cjs-module-lexer: 1.4.1 + fflate: 0.8.2 + lru-cache: 10.4.3 + semver: 7.6.3 + typescript: 5.6.3 + validate-npm-package-name: 5.0.1 + '@babel/code-frame@7.26.2': dependencies: '@babel/helper-validator-identifier': 7.25.9 @@ -8001,6 +8120,9 @@ snapshots: dependencies: mime: 3.0.0 + '@colors/colors@1.5.0': + optional: true + '@discoveryjs/json-ext@0.5.7': {} '@es-joy/jsdoccomment@0.49.0': @@ -10378,6 +10500,10 @@ snapshots: dependencies: type-fest: 0.21.3 + ansi-escapes@7.0.0: + dependencies: + environment: 1.1.0 + ansi-html-community@0.0.8: {} ansi-regex@5.0.1: {} @@ -10398,6 +10524,8 @@ snapshots: ansis@3.3.2: {} + any-promise@1.3.0: {} + anymatch@3.1.3: dependencies: normalize-path: 3.0.0 @@ -10701,6 +10829,8 @@ snapshots: dependencies: consola: 3.2.3 + cjs-module-lexer@1.4.1: {} + clean-regexp@1.0.0: dependencies: escape-string-regexp: 1.0.5 @@ -10709,12 +10839,33 @@ snapshots: clear@0.1.0: {} + cli-highlight@2.1.11: + dependencies: + chalk: 4.1.2 + highlight.js: 10.7.3 + mz: 2.7.0 + parse5: 5.1.1 + parse5-htmlparser2-tree-adapter: 6.0.1 + yargs: 16.2.0 + + cli-table3@0.6.5: + dependencies: + string-width: 4.2.3 + optionalDependencies: + '@colors/colors': 1.5.0 + clipboardy@4.0.0: dependencies: execa: 8.0.1 is-wsl: 3.1.0 is64bit: 2.0.0 + cliui@7.0.4: + dependencies: + string-width: 4.2.3 + strip-ansi: 6.0.1 + wrap-ansi: 7.0.0 + cliui@8.0.1: dependencies: string-width: 4.2.3 @@ -11167,6 +11318,8 @@ snapshots: env-paths@2.2.1: {} + environment@1.1.0: {} + errno@0.1.8: dependencies: prr: 1.0.1 @@ -11591,6 +11744,8 @@ snapshots: optionalDependencies: picomatch: 4.0.2 + fflate@0.8.2: {} + file-entry-cache@8.0.0: dependencies: flat-cache: 4.0.1 @@ -11963,6 +12118,8 @@ snapshots: he@1.2.0: {} + highlight.js@10.7.3: {} + hookable@5.5.3: {} hosted-git-info@2.8.9: {} @@ -12633,6 +12790,19 @@ snapshots: markdown-it: 14.1.0 markdownlint-micromark: 0.1.12 + marked-terminal@7.2.1(marked@9.1.6): + dependencies: + ansi-escapes: 7.0.0 + ansi-regex: 6.1.0 + chalk: 5.3.0 + cli-highlight: 2.1.11 + cli-table3: 0.6.5 + marked: 9.1.6 + node-emoji: 2.1.3 + supports-hyperlinks: 3.1.0 + + marked@9.1.6: {} + mdast-util-find-and-replace@3.0.1: dependencies: '@types/mdast': 4.0.4 @@ -13073,6 +13243,12 @@ snapshots: muggle-string@0.4.1: {} + mz@2.7.0: + dependencies: + any-promise: 1.3.0 + object-assign: 4.1.1 + thenify-all: 1.6.0 + nanoid@3.3.7: {} nanoid@5.0.7: {} @@ -13449,6 +13625,14 @@ snapshots: dependencies: parse-path: 7.0.0 + parse5-htmlparser2-tree-adapter@6.0.1: + dependencies: + parse5: 6.0.1 + + parse5@5.1.1: {} + + parse5@6.0.1: {} + parse5@7.2.1: dependencies: entities: 4.5.0 @@ -14528,6 +14712,11 @@ snapshots: supports-color@9.4.0: {} + supports-hyperlinks@3.1.0: + dependencies: + has-flag: 4.0.0 + supports-color: 7.2.0 + supports-preserve-symlinks-flag@1.0.0: {} svg-tags@1.0.0: {} @@ -14607,6 +14796,14 @@ snapshots: dependencies: b4a: 1.6.6 + thenify-all@1.6.0: + dependencies: + thenify: 3.3.1 + + thenify@3.3.1: + dependencies: + any-promise: 1.3.0 + thingies@1.21.0(tslib@2.7.0): dependencies: tslib: 2.7.0 @@ -15016,6 +15213,8 @@ snapshots: spdx-correct: 3.2.0 spdx-expression-parse: 3.0.1 + validate-npm-package-name@5.0.1: {} + version-guard@1.1.3: {} vfile-location@5.0.3: @@ -15583,8 +15782,20 @@ snapshots: yaml@2.5.1: {} + yargs-parser@20.2.9: {} + yargs-parser@21.1.1: {} + yargs@16.2.0: + dependencies: + cliui: 7.0.4 + escalade: 3.2.0 + get-caller-file: 2.0.5 + require-directory: 2.1.1 + string-width: 4.2.3 + y18n: 5.0.8 + yargs-parser: 20.2.9 + yargs@17.7.2: dependencies: cliui: 8.0.1 From 8c956db8662248df6658d2b015b87e180031ef78 Mon Sep 17 00:00:00 2001 From: Julien Huang Date: Mon, 9 Dec 2024 13:38:25 +0100 Subject: [PATCH 2/2] refactor(nuxt): prefix all core modules with `nuxt:` (#30028) --- packages/nuxt/src/components/module.ts | 2 +- packages/nuxt/src/core/schema.ts | 2 +- packages/nuxt/src/core/templates.ts | 3 +-- packages/nuxt/src/head/module.ts | 2 +- packages/nuxt/src/imports/module.ts | 2 +- packages/nuxt/src/pages/module.ts | 3 ++- 6 files changed, 7 insertions(+), 7 deletions(-) diff --git a/packages/nuxt/src/components/module.ts b/packages/nuxt/src/components/module.ts index a2a1d8ca7d7f..7a8d145eafa7 100644 --- a/packages/nuxt/src/components/module.ts +++ b/packages/nuxt/src/components/module.ts @@ -28,7 +28,7 @@ export type getComponentsT = (mode?: 'client' | 'server' | 'all') => Component[] export default defineNuxtModule({ meta: { - name: 'components', + name: 'nuxt:components', configKey: 'components', }, defaults: { diff --git a/packages/nuxt/src/core/schema.ts b/packages/nuxt/src/core/schema.ts index a2bf41d7dd87..5e3750bfc634 100644 --- a/packages/nuxt/src/core/schema.ts +++ b/packages/nuxt/src/core/schema.ts @@ -16,7 +16,7 @@ import { createJiti } from 'jiti' export default defineNuxtModule({ meta: { - name: 'nuxt-config-schema', + name: 'nuxt:nuxt-config-schema', }, async setup (_, nuxt) { const resolver = createResolver(import.meta.url) diff --git a/packages/nuxt/src/core/templates.ts b/packages/nuxt/src/core/templates.ts index ed2dee805431..0ec7df486028 100644 --- a/packages/nuxt/src/core/templates.ts +++ b/packages/nuxt/src/core/templates.ts @@ -177,7 +177,6 @@ export { } }, } -const adHocModules = ['router', 'pages', 'imports', 'meta', 'components', 'nuxt-config-schema'] const IMPORT_NAME_RE = /\.\w+$/ const GIT_RE = /^git\+/ export const schemaTemplate: NuxtTemplate = { @@ -187,7 +186,7 @@ export const schemaTemplate: NuxtTemplate = { const getImportName = (name: string) => (name[0] === '.' ? './' + join(relativeRoot, name) : name).replace(IMPORT_NAME_RE, '') const modules = nuxt.options._installedModules - .filter(m => m.meta && m.meta.configKey && m.meta.name && !adHocModules.includes(m.meta.name)) + .filter(m => m.meta && m.meta.configKey && m.meta.name && !m.meta.name.startsWith('nuxt:') && m.meta.name !== 'nuxt-config-schema') .map(m => [genString(m.meta.configKey), getImportName(m.entryPath || m.meta.name), m] as const) const privateRuntimeConfig = Object.create(null) diff --git a/packages/nuxt/src/head/module.ts b/packages/nuxt/src/head/module.ts index d8b4d74a01d1..843eb45d5cd4 100644 --- a/packages/nuxt/src/head/module.ts +++ b/packages/nuxt/src/head/module.ts @@ -7,7 +7,7 @@ const components = ['NoScript', 'Link', 'Base', 'Title', 'Meta', 'Style', 'Head' export default defineNuxtModule({ meta: { - name: 'meta', + name: 'nuxt:meta', configKey: 'unhead', }, async setup (options, nuxt) { diff --git a/packages/nuxt/src/imports/module.ts b/packages/nuxt/src/imports/module.ts index 5465a180e26c..2714470a43b8 100644 --- a/packages/nuxt/src/imports/module.ts +++ b/packages/nuxt/src/imports/module.ts @@ -13,7 +13,7 @@ import { defaultPresets } from './presets' export default defineNuxtModule>({ meta: { - name: 'imports', + name: 'nuxt:imports', configKey: 'imports', }, defaults: nuxt => ({ diff --git a/packages/nuxt/src/pages/module.ts b/packages/nuxt/src/pages/module.ts index 8769ba2ae5e5..b1d3b2493993 100644 --- a/packages/nuxt/src/pages/module.ts +++ b/packages/nuxt/src/pages/module.ts @@ -23,7 +23,8 @@ const OPTIONAL_PARAM_RE = /^\/?:.*(?:\?|\(\.\*\)\*)$/ export default defineNuxtModule({ meta: { - name: 'pages', + name: 'nuxt:pages', + configKey: 'pages', }, async setup (_options, nuxt) { const useExperimentalTypedPages = nuxt.options.experimental.typedPages