nitro-nightly 3.1.0-20251025-144733-946505c1 → 3.1.0-20251026-222805-a13234bf

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -1,8 +1,8 @@
1
1
  import { n as nitro } from './plugin.mjs';
2
+ import { isTest } from 'std-env';
2
3
  import './index.mjs';
3
4
  import 'consola';
4
5
  import 'hookable';
5
- import 'nitro/runtime/meta';
6
6
  import 'node:fs';
7
7
  import 'node:fs/promises';
8
8
  import 'node:url';
@@ -22,7 +22,6 @@ import 'os';
22
22
  import 'crypto';
23
23
  import './app.mjs';
24
24
  import 'node:worker_threads';
25
- import 'std-env';
26
25
  import 'fs/promises';
27
26
  import 'events';
28
27
  import 'node:stream';
@@ -41,6 +40,7 @@ import 'youch';
41
40
  import 'source-map';
42
41
  import 'srvx';
43
42
  import 'klona/full';
43
+ import 'nitro/runtime/meta';
44
44
  import 'node:module';
45
45
  import 'ofetch';
46
46
  import 'klona';
@@ -77,7 +77,8 @@ async function viteBuild(nitro$1) {
77
77
  const { createBuilder } = await import('vite');
78
78
  const builder = await createBuilder({
79
79
  base: nitro$1.options.rootDir,
80
- plugins: [await nitro({ _nitro: nitro$1 })]
80
+ plugins: [await nitro({ _nitro: nitro$1 })],
81
+ logLevel: isTest ? "warn" : void 0
81
82
  });
82
83
  await builder.buildApp();
83
84
  }
@@ -4,7 +4,6 @@ import 'node:process';
4
4
  import 'scule';
5
5
  import 'consola';
6
6
  import 'hookable';
7
- import 'nitro/runtime/meta';
8
7
  import 'node:fs';
9
8
  import 'node:fs/promises';
10
9
  import 'node:url';
@@ -41,6 +40,7 @@ import 'youch';
41
40
  import 'source-map';
42
41
  import 'srvx';
43
42
  import 'klona/full';
43
+ import 'nitro/runtime/meta';
44
44
  import 'node:module';
45
45
  import 'ofetch';
46
46
  import 'klona';
@@ -1,6 +1,5 @@
1
1
  import consola, { consola as consola$1 } from 'consola';
2
- import { createHooks, createDebugger } from 'hookable';
3
- import { runtimeDir, pkgDir } from 'nitro/runtime/meta';
2
+ import { Hookable, createDebugger } from 'hookable';
4
3
  import fs, { promises, statSync, realpathSync, lstatSync, readFileSync, existsSync, accessSync, constants as constants$1 } from 'node:fs';
5
4
  import fsp, { readFile as readFile$1, rm, stat, mkdir, writeFile as writeFile$1 } from 'node:fs/promises';
6
5
  import { fileURLToPath as fileURLToPath$1, pathToFileURL as pathToFileURL$1, URL as URL$1 } from 'node:url';
@@ -21,6 +20,7 @@ import require$$2 from 'os';
21
20
  import require$$3 from 'crypto';
22
21
  import { g as getDefaultExportFromCjs, b as getAugmentedNamespace, d as debounce } from './app.mjs';
23
22
  import { klona } from 'klona/full';
23
+ import { runtimeDir, pkgDir } from 'nitro/runtime/meta';
24
24
  import { isDebug, isTest } from 'std-env';
25
25
  import { joinURL, withLeadingSlash, withoutTrailingSlash, withTrailingSlash, withBase } from 'ufo';
26
26
  import { builtinModules, createRequire as createRequire$1 } from 'node:module';
@@ -20696,7 +20696,7 @@ async function createNitro(config = {}, opts = {}) {
20696
20696
  const options = await loadOptions(config, opts);
20697
20697
  const nitro = {
20698
20698
  options,
20699
- hooks: createHooks(),
20699
+ hooks: new Hookable(),
20700
20700
  vfs: {},
20701
20701
  routing: {},
20702
20702
  logger: consola$1.withTag("nitro"),
@@ -20715,7 +20715,6 @@ async function createNitro(config = {}, opts = {}) {
20715
20715
  });
20716
20716
  if (nitro.options.debug) {
20717
20717
  createDebugger(nitro.hooks, { tag: "nitro" });
20718
- nitro.options.plugins.push(join(runtimeDir, "internal/debug"));
20719
20718
  }
20720
20719
  if (nitro.options.logLevel !== void 0) {
20721
20720
  nitro.logger.level = nitro.options.logLevel;
@@ -1,7 +1,6 @@
1
1
  import { N } from './index.mjs';
2
2
  import 'consola';
3
3
  import 'hookable';
4
- import 'nitro/runtime/meta';
5
4
  import 'node:fs';
6
5
  import 'node:fs/promises';
7
6
  import 'node:url';
@@ -40,6 +39,7 @@ import 'youch';
40
39
  import 'source-map';
41
40
  import 'srvx';
42
41
  import 'klona/full';
42
+ import 'nitro/runtime/meta';
43
43
  import 'node:module';
44
44
  import 'ofetch';
45
45
  import 'klona';
@@ -1,7 +1,6 @@
1
1
  export { h as parseJSONC } from './index.mjs';
2
2
  import 'consola';
3
3
  import 'hookable';
4
- import 'nitro/runtime/meta';
5
4
  import 'node:fs';
6
5
  import 'node:fs/promises';
7
6
  import 'node:url';
@@ -40,6 +39,7 @@ import 'youch';
40
39
  import 'source-map';
41
40
  import 'srvx';
42
41
  import 'klona/full';
42
+ import 'nitro/runtime/meta';
43
43
  import 'node:module';
44
44
  import 'ofetch';
45
45
  import 'klona';
@@ -1,7 +1,6 @@
1
1
  import { N } from './index.mjs';
2
2
  import 'consola';
3
3
  import 'hookable';
4
- import 'nitro/runtime/meta';
5
4
  import 'node:fs';
6
5
  import 'node:fs/promises';
7
6
  import 'node:url';
@@ -40,6 +39,7 @@ import 'youch';
40
39
  import 'source-map';
41
40
  import 'srvx';
42
41
  import 'klona/full';
42
+ import 'nitro/runtime/meta';
43
43
  import 'node:module';
44
44
  import 'ofetch';
45
45
  import 'klona';
@@ -1,7 +1,6 @@
1
1
  import { C as C$1, N as N$1 } from './index.mjs';
2
2
  import 'consola';
3
3
  import 'hookable';
4
- import 'nitro/runtime/meta';
5
4
  import 'node:fs';
6
5
  import 'node:fs/promises';
7
6
  import 'node:url';
@@ -40,6 +39,7 @@ import 'youch';
40
39
  import 'source-map';
41
40
  import 'srvx';
42
41
  import 'klona/full';
42
+ import 'nitro/runtime/meta';
43
43
  import 'node:module';
44
44
  import 'ofetch';
45
45
  import 'klona';
package/dist/index.mjs CHANGED
@@ -3,7 +3,6 @@ export { b as build, p as prerender, w as writeTypes } from './_chunks/index3.mj
3
3
  export { c as createDevServer } from './_chunks/server.mjs';
4
4
  import 'consola';
5
5
  import 'hookable';
6
- import 'nitro/runtime/meta';
7
6
  import 'node:fs';
8
7
  import 'node:fs/promises';
9
8
  import 'node:url';
@@ -42,6 +41,7 @@ import 'youch';
42
41
  import 'source-map';
43
42
  import 'srvx';
44
43
  import 'klona/full';
44
+ import 'nitro/runtime/meta';
45
45
  import 'node:module';
46
46
  import 'ofetch';
47
47
  import 'klona';
@@ -1,290 +1,267 @@
1
+ //#region src/utils.ts
1
2
  function flatHooks(configHooks, hooks = {}, parentName) {
2
- for (const key in configHooks) {
3
- const subHook = configHooks[key];
4
- const name = parentName ? `${parentName}:${key}` : key;
5
- if (typeof subHook === "object" && subHook !== null) {
6
- flatHooks(subHook, hooks, name);
7
- } else if (typeof subHook === "function") {
8
- hooks[name] = subHook;
9
- }
10
- }
11
- return hooks;
3
+ for (const key in configHooks) {
4
+ const subHook = configHooks[key];
5
+ const name = parentName ? `${parentName}:${key}` : key;
6
+ if (typeof subHook === "object" && subHook !== null) flatHooks(subHook, hooks, name);
7
+ else if (typeof subHook === "function") hooks[name] = subHook;
8
+ }
9
+ return hooks;
12
10
  }
13
11
  function mergeHooks(...hooks) {
14
- const finalHooks = {};
15
- for (const hook of hooks) {
16
- const flatenHook = flatHooks(hook);
17
- for (const key in flatenHook) {
18
- if (finalHooks[key]) {
19
- finalHooks[key].push(flatenHook[key]);
20
- } else {
21
- finalHooks[key] = [flatenHook[key]];
22
- }
23
- }
24
- }
25
- for (const key in finalHooks) {
26
- if (finalHooks[key].length > 1) {
27
- const array = finalHooks[key];
28
- finalHooks[key] = (...arguments_) => serial(array, (function_) => function_(...arguments_));
29
- } else {
30
- finalHooks[key] = finalHooks[key][0];
31
- }
32
- }
33
- return finalHooks;
12
+ const finalHooks = {};
13
+ for (const hook of hooks) {
14
+ const flatenHook = flatHooks(hook);
15
+ for (const key in flatenHook) if (finalHooks[key]) finalHooks[key].push(flatenHook[key]);
16
+ else finalHooks[key] = [flatenHook[key]];
17
+ }
18
+ for (const key in finalHooks) if (finalHooks[key].length > 1) {
19
+ const array = finalHooks[key];
20
+ finalHooks[key] = (...arguments_) => serial(array, (function_) => function_(...arguments_));
21
+ } else finalHooks[key] = finalHooks[key][0];
22
+ return finalHooks;
34
23
  }
35
24
  function serial(tasks, function_) {
36
- return tasks.reduce(
37
- (promise, task) => promise.then(() => function_(task)),
38
- Promise.resolve()
39
- );
25
+ return tasks.reduce((promise, task) => promise.then(() => function_(task)), Promise.resolve());
26
+ }
27
+ const createTask = /* @__PURE__ */ (() => {
28
+ if (console.createTask) return console.createTask;
29
+ const defaultTask = { run: (fn) => fn() };
30
+ return () => defaultTask;
31
+ })();
32
+ function callHooks(hooks, args, startIndex, task) {
33
+ for (let i = startIndex; i < hooks.length; i += 1) try {
34
+ const result = task ? task.run(() => hooks[i](...args)) : hooks[i](...args);
35
+ if (result instanceof Promise) return result.then(() => callHooks(hooks, args, i + 1, task));
36
+ } catch (error) {
37
+ return Promise.reject(error);
38
+ }
40
39
  }
41
- const defaultTask = { run: (function_) => function_() };
42
- const _createTask = () => defaultTask;
43
- const createTask = typeof console.createTask !== "undefined" ? console.createTask : _createTask;
44
40
  function serialTaskCaller(hooks, args) {
45
- const name = args.shift();
46
- const task = createTask(name);
47
- return hooks.reduce(
48
- (promise, hookFunction) => promise.then(() => task.run(() => hookFunction(...args))),
49
- Promise.resolve()
50
- );
41
+ if (hooks.length > 0) return callHooks(hooks, args, 0, createTask(args.shift()));
51
42
  }
52
43
  function parallelTaskCaller(hooks, args) {
53
- const name = args.shift();
54
- const task = createTask(name);
55
- return Promise.all(hooks.map((hook) => task.run(() => hook(...args))));
44
+ if (hooks.length > 0) {
45
+ const task = createTask(args.shift());
46
+ return Promise.all(hooks.map((hook) => task.run(() => hook(...args))));
47
+ }
56
48
  }
49
+ /** @deprecated */
57
50
  function serialCaller(hooks, arguments_) {
58
- return hooks.reduce(
59
- (promise, hookFunction) => promise.then(() => hookFunction(...arguments_ || [])),
60
- Promise.resolve()
61
- );
51
+ return hooks.reduce((promise, hookFunction) => promise.then(() => hookFunction(...arguments_ || [])), Promise.resolve());
62
52
  }
53
+ /** @deprecated */
63
54
  function parallelCaller(hooks, args) {
64
- return Promise.all(hooks.map((hook) => hook(...args || [])));
55
+ return Promise.all(hooks.map((hook) => hook(...args || [])));
65
56
  }
66
57
  function callEachWith(callbacks, arg0) {
67
- for (const callback of [...callbacks]) {
68
- callback(arg0);
69
- }
58
+ for (const callback of [...callbacks]) callback(arg0);
70
59
  }
71
60
 
72
- class Hookable {
73
- constructor() {
74
- this._hooks = {};
75
- this._before = void 0;
76
- this._after = void 0;
77
- this._deprecatedMessages = void 0;
78
- this._deprecatedHooks = {};
79
- this.hook = this.hook.bind(this);
80
- this.callHook = this.callHook.bind(this);
81
- this.callHookWith = this.callHookWith.bind(this);
82
- }
83
- hook(name, function_, options = {}) {
84
- if (!name || typeof function_ !== "function") {
85
- return () => {
86
- };
87
- }
88
- const originalName = name;
89
- let dep;
90
- while (this._deprecatedHooks[name]) {
91
- dep = this._deprecatedHooks[name];
92
- name = dep.to;
93
- }
94
- if (dep && !options.allowDeprecated) {
95
- let message = dep.message;
96
- if (!message) {
97
- message = `${originalName} hook has been deprecated` + (dep.to ? `, please use ${dep.to}` : "");
98
- }
99
- if (!this._deprecatedMessages) {
100
- this._deprecatedMessages = /* @__PURE__ */ new Set();
101
- }
102
- if (!this._deprecatedMessages.has(message)) {
103
- console.warn(message);
104
- this._deprecatedMessages.add(message);
105
- }
106
- }
107
- if (!function_.name) {
108
- try {
109
- Object.defineProperty(function_, "name", {
110
- get: () => "_" + name.replace(/\W+/g, "_") + "_hook_cb",
111
- configurable: true
112
- });
113
- } catch {
114
- }
115
- }
116
- this._hooks[name] = this._hooks[name] || [];
117
- this._hooks[name].push(function_);
118
- return () => {
119
- if (function_) {
120
- this.removeHook(name, function_);
121
- function_ = void 0;
122
- }
123
- };
124
- }
125
- hookOnce(name, function_) {
126
- let _unreg;
127
- let _function = (...arguments_) => {
128
- if (typeof _unreg === "function") {
129
- _unreg();
130
- }
131
- _unreg = void 0;
132
- _function = void 0;
133
- return function_(...arguments_);
134
- };
135
- _unreg = this.hook(name, _function);
136
- return _unreg;
137
- }
138
- removeHook(name, function_) {
139
- if (this._hooks[name]) {
140
- const index = this._hooks[name].indexOf(function_);
141
- if (index !== -1) {
142
- this._hooks[name].splice(index, 1);
143
- }
144
- if (this._hooks[name].length === 0) {
145
- delete this._hooks[name];
146
- }
147
- }
148
- }
149
- deprecateHook(name, deprecated) {
150
- this._deprecatedHooks[name] = typeof deprecated === "string" ? { to: deprecated } : deprecated;
151
- const _hooks = this._hooks[name] || [];
152
- delete this._hooks[name];
153
- for (const hook of _hooks) {
154
- this.hook(name, hook);
155
- }
156
- }
157
- deprecateHooks(deprecatedHooks) {
158
- Object.assign(this._deprecatedHooks, deprecatedHooks);
159
- for (const name in deprecatedHooks) {
160
- this.deprecateHook(name, deprecatedHooks[name]);
161
- }
162
- }
163
- addHooks(configHooks) {
164
- const hooks = flatHooks(configHooks);
165
- const removeFns = Object.keys(hooks).map(
166
- (key) => this.hook(key, hooks[key])
167
- );
168
- return () => {
169
- for (const unreg of removeFns.splice(0, removeFns.length)) {
170
- unreg();
171
- }
172
- };
173
- }
174
- removeHooks(configHooks) {
175
- const hooks = flatHooks(configHooks);
176
- for (const key in hooks) {
177
- this.removeHook(key, hooks[key]);
178
- }
179
- }
180
- removeAllHooks() {
181
- for (const key in this._hooks) {
182
- delete this._hooks[key];
183
- }
184
- }
185
- callHook(name, ...arguments_) {
186
- arguments_.unshift(name);
187
- return this.callHookWith(serialTaskCaller, name, ...arguments_);
188
- }
189
- callHookParallel(name, ...arguments_) {
190
- arguments_.unshift(name);
191
- return this.callHookWith(parallelTaskCaller, name, ...arguments_);
192
- }
193
- callHookWith(caller, name, ...arguments_) {
194
- const event = this._before || this._after ? { name, args: arguments_, context: {} } : void 0;
195
- if (this._before) {
196
- callEachWith(this._before, event);
197
- }
198
- const result = caller(
199
- name in this._hooks ? [...this._hooks[name]] : [],
200
- arguments_
201
- );
202
- if (result instanceof Promise) {
203
- return result.finally(() => {
204
- if (this._after && event) {
205
- callEachWith(this._after, event);
206
- }
207
- });
208
- }
209
- if (this._after && event) {
210
- callEachWith(this._after, event);
211
- }
212
- return result;
213
- }
214
- beforeEach(function_) {
215
- this._before = this._before || [];
216
- this._before.push(function_);
217
- return () => {
218
- if (this._before !== void 0) {
219
- const index = this._before.indexOf(function_);
220
- if (index !== -1) {
221
- this._before.splice(index, 1);
222
- }
223
- }
224
- };
225
- }
226
- afterEach(function_) {
227
- this._after = this._after || [];
228
- this._after.push(function_);
229
- return () => {
230
- if (this._after !== void 0) {
231
- const index = this._after.indexOf(function_);
232
- if (index !== -1) {
233
- this._after.splice(index, 1);
234
- }
235
- }
236
- };
237
- }
238
- }
61
+ //#endregion
62
+ //#region src/hookable.ts
63
+ var Hookable = class {
64
+ _hooks;
65
+ _before;
66
+ _after;
67
+ _deprecatedHooks;
68
+ _deprecatedMessages;
69
+ constructor() {
70
+ this._hooks = {};
71
+ this._before = void 0;
72
+ this._after = void 0;
73
+ this._deprecatedMessages = void 0;
74
+ this._deprecatedHooks = {};
75
+ this.hook = this.hook.bind(this);
76
+ this.callHook = this.callHook.bind(this);
77
+ this.callHookWith = this.callHookWith.bind(this);
78
+ }
79
+ hook(name, function_, options = {}) {
80
+ if (!name || typeof function_ !== "function") return () => {};
81
+ const originalName = name;
82
+ let dep;
83
+ while (this._deprecatedHooks[name]) {
84
+ dep = this._deprecatedHooks[name];
85
+ name = dep.to;
86
+ }
87
+ if (dep && !options.allowDeprecated) {
88
+ let message = dep.message;
89
+ if (!message) message = `${originalName} hook has been deprecated` + (dep.to ? `, please use ${dep.to}` : "");
90
+ if (!this._deprecatedMessages) this._deprecatedMessages = /* @__PURE__ */ new Set();
91
+ if (!this._deprecatedMessages.has(message)) {
92
+ console.warn(message);
93
+ this._deprecatedMessages.add(message);
94
+ }
95
+ }
96
+ if (!function_.name) try {
97
+ Object.defineProperty(function_, "name", {
98
+ get: () => "_" + name.replace(/\W+/g, "_") + "_hook_cb",
99
+ configurable: true
100
+ });
101
+ } catch {}
102
+ this._hooks[name] = this._hooks[name] || [];
103
+ this._hooks[name].push(function_);
104
+ return () => {
105
+ if (function_) {
106
+ this.removeHook(name, function_);
107
+ function_ = void 0;
108
+ }
109
+ };
110
+ }
111
+ hookOnce(name, function_) {
112
+ let _unreg;
113
+ let _function = (...arguments_) => {
114
+ if (typeof _unreg === "function") _unreg();
115
+ _unreg = void 0;
116
+ _function = void 0;
117
+ return function_(...arguments_);
118
+ };
119
+ _unreg = this.hook(name, _function);
120
+ return _unreg;
121
+ }
122
+ removeHook(name, function_) {
123
+ const hooks = this._hooks[name];
124
+ if (hooks) {
125
+ const index = hooks.indexOf(function_);
126
+ if (index !== -1) hooks.splice(index, 1);
127
+ if (hooks.length === 0) this._hooks[name] = void 0;
128
+ }
129
+ }
130
+ deprecateHook(name, deprecated) {
131
+ this._deprecatedHooks[name] = typeof deprecated === "string" ? { to: deprecated } : deprecated;
132
+ const _hooks = this._hooks[name] || [];
133
+ this._hooks[name] = void 0;
134
+ for (const hook of _hooks) this.hook(name, hook);
135
+ }
136
+ deprecateHooks(deprecatedHooks) {
137
+ for (const name in deprecatedHooks) this.deprecateHook(name, deprecatedHooks[name]);
138
+ }
139
+ addHooks(configHooks) {
140
+ const hooks = flatHooks(configHooks);
141
+ const removeFns = Object.keys(hooks).map((key) => this.hook(key, hooks[key]));
142
+ return () => {
143
+ for (const unreg of removeFns) unreg();
144
+ removeFns.length = 0;
145
+ };
146
+ }
147
+ removeHooks(configHooks) {
148
+ const hooks = flatHooks(configHooks);
149
+ for (const key in hooks) this.removeHook(key, hooks[key]);
150
+ }
151
+ removeAllHooks() {
152
+ this._hooks = {};
153
+ }
154
+ callHook(name, ...args) {
155
+ return this.callHookWith(serialTaskCaller, name, args);
156
+ }
157
+ callHookParallel(name, ...args) {
158
+ return this.callHookWith(parallelTaskCaller, name, args);
159
+ }
160
+ callHookWith(caller, name, args) {
161
+ const event = this._before || this._after ? {
162
+ name,
163
+ args,
164
+ context: {}
165
+ } : void 0;
166
+ if (this._before) callEachWith(this._before, event);
167
+ const _args = args?.length ? [name, ...args] : [name];
168
+ const result = caller(this._hooks[name] ? [...this._hooks[name]] : [], _args);
169
+ if (result instanceof Promise) return result.finally(() => {
170
+ if (this._after && event) callEachWith(this._after, event);
171
+ });
172
+ if (this._after && event) callEachWith(this._after, event);
173
+ return result;
174
+ }
175
+ beforeEach(function_) {
176
+ this._before = this._before || [];
177
+ this._before.push(function_);
178
+ return () => {
179
+ if (this._before !== void 0) {
180
+ const index = this._before.indexOf(function_);
181
+ if (index !== -1) this._before.splice(index, 1);
182
+ }
183
+ };
184
+ }
185
+ afterEach(function_) {
186
+ this._after = this._after || [];
187
+ this._after.push(function_);
188
+ return () => {
189
+ if (this._after !== void 0) {
190
+ const index = this._after.indexOf(function_);
191
+ if (index !== -1) this._after.splice(index, 1);
192
+ }
193
+ };
194
+ }
195
+ };
239
196
  function createHooks() {
240
- return new Hookable();
197
+ return new Hookable();
241
198
  }
199
+ var HookableCore = class {
200
+ _hooks;
201
+ constructor() {
202
+ this._hooks = {};
203
+ }
204
+ hook(name, fn) {
205
+ if (!name || typeof fn !== "function") return () => {};
206
+ this._hooks[name] = this._hooks[name] || [];
207
+ this._hooks[name].push(fn);
208
+ return () => {
209
+ if (fn) {
210
+ this.removeHook(name, fn);
211
+ fn = void 0;
212
+ }
213
+ };
214
+ }
215
+ removeHook(name, function_) {
216
+ const hooks = this._hooks[name];
217
+ if (hooks) {
218
+ const index = hooks.indexOf(function_);
219
+ if (index !== -1) hooks.splice(index, 1);
220
+ if (hooks.length === 0) this._hooks[name] = void 0;
221
+ }
222
+ }
223
+ callHook(name, ...args) {
224
+ const hooks = this._hooks[name];
225
+ if (!hooks || hooks.length === 0) return;
226
+ return callHooks(hooks, args, 0);
227
+ }
228
+ };
242
229
 
230
+ //#endregion
231
+ //#region src/debugger.ts
243
232
  const isBrowser = typeof window !== "undefined";
233
+ /** Start debugging hook names and timing in console */
244
234
  function createDebugger(hooks, _options = {}) {
245
- const options = {
246
- inspect: isBrowser,
247
- group: isBrowser,
248
- filter: () => true,
249
- ..._options
250
- };
251
- const _filter = options.filter;
252
- const filter = typeof _filter === "string" ? (name) => name.startsWith(_filter) : _filter;
253
- const _tag = options.tag ? `[${options.tag}] ` : "";
254
- const logPrefix = (event) => _tag + event.name + "".padEnd(event._id, "\0");
255
- const _idCtr = {};
256
- const unsubscribeBefore = hooks.beforeEach((event) => {
257
- if (filter !== void 0 && !filter(event.name)) {
258
- return;
259
- }
260
- _idCtr[event.name] = _idCtr[event.name] || 0;
261
- event._id = _idCtr[event.name]++;
262
- console.time(logPrefix(event));
263
- });
264
- const unsubscribeAfter = hooks.afterEach((event) => {
265
- if (filter !== void 0 && !filter(event.name)) {
266
- return;
267
- }
268
- if (options.group) {
269
- console.groupCollapsed(event.name);
270
- }
271
- if (options.inspect) {
272
- console.timeLog(logPrefix(event), event.args);
273
- } else {
274
- console.timeEnd(logPrefix(event));
275
- }
276
- if (options.group) {
277
- console.groupEnd();
278
- }
279
- _idCtr[event.name]--;
280
- });
281
- return {
282
- /** Stop debugging and remove listeners */
283
- close: () => {
284
- unsubscribeBefore();
285
- unsubscribeAfter();
286
- }
287
- };
235
+ const options = {
236
+ inspect: isBrowser,
237
+ group: isBrowser,
238
+ filter: () => true,
239
+ ..._options
240
+ };
241
+ const _filter = options.filter;
242
+ const filter = typeof _filter === "string" ? (name) => name.startsWith(_filter) : _filter;
243
+ const _tag = options.tag ? `[${options.tag}] ` : "";
244
+ const logPrefix = (event) => _tag + event.name + "".padEnd(event._id, "\0");
245
+ const _idCtr = {};
246
+ const unsubscribeBefore = hooks.beforeEach((event) => {
247
+ if (filter !== void 0 && !filter(event.name)) return;
248
+ _idCtr[event.name] = _idCtr[event.name] || 0;
249
+ event._id = _idCtr[event.name]++;
250
+ console.time(logPrefix(event));
251
+ });
252
+ const unsubscribeAfter = hooks.afterEach((event) => {
253
+ if (filter !== void 0 && !filter(event.name)) return;
254
+ if (options.group) console.groupCollapsed(event.name);
255
+ if (options.inspect) console.timeLog(logPrefix(event), event.args);
256
+ else console.timeEnd(logPrefix(event));
257
+ if (options.group) console.groupEnd();
258
+ _idCtr[event.name]--;
259
+ });
260
+ return { close: () => {
261
+ unsubscribeBefore();
262
+ unsubscribeAfter();
263
+ } };
288
264
  }
289
265
 
290
- export { Hookable, createDebugger, createHooks, flatHooks, mergeHooks, parallelCaller, serial, serialCaller };
266
+ //#endregion
267
+ export { Hookable, HookableCore, createDebugger, createHooks, flatHooks, mergeHooks, parallelCaller, serial, serialCaller };
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "hookable",
3
- "version": "5.5.3",
3
+ "version": "6.0.0-rc.1",
4
4
  "description": "Awaitable hook system",
5
5
  "keywords": [
6
6
  "hook",
@@ -11,39 +11,42 @@
11
11
  ],
12
12
  "repository": "unjs/hookable",
13
13
  "license": "MIT",
14
+ "sideEffects": false,
15
+ "type": "module",
14
16
  "exports": {
15
- "import": "./dist/index.mjs",
16
- "types": "./dist/index.d.ts",
17
- "require": "./dist/index.cjs"
17
+ ".": "./dist/index.mjs"
18
18
  },
19
- "main": "./dist/index.cjs",
20
- "module": "./dist/index.mjs",
21
- "types": "./dist/index.d.ts",
19
+ "main": "./dist/index.mjs",
20
+ "types": "./dist/index.d.mts",
22
21
  "files": [
23
22
  "dist"
24
23
  ],
25
- "devDependencies": {
26
- "@types/node": "^18.15.11",
27
- "@vitest/coverage-c8": "^0.29.8",
28
- "changelogen": "^0.5.2",
29
- "eslint": "^8.37.0",
30
- "eslint-config-unjs": "^0.1.0",
31
- "expect-type": "^0.15.0",
32
- "prettier": "^2.8.7",
33
- "typescript": "^5.0.2",
34
- "unbuild": "^1.1.2",
35
- "vite": "^4.2.1",
36
- "vitest": "^0.29.8"
37
- },
38
- "packageManager": "pnpm@8.0.0",
39
24
  "scripts": {
40
- "build": "unbuild",
25
+ "bench": "node --expose-gc --allow-natives-syntax test/bench.ts",
26
+ "build": "obuild src/index.ts",
41
27
  "dev": "vitest",
42
- "lint": "eslint --cache --ext .ts,.js,.mjs,.cjs . && prettier -c src test",
43
- "lint:fix": "eslint --cache --ext .ts,.js,.mjs,.cjs . --fix && prettier -c src test -w",
28
+ "lint": "eslint --cache . && prettier -c src test",
29
+ "lint:fix": "eslint --cache . --fix && prettier -c src test -w",
44
30
  "prepublish": "pnpm build",
45
- "release": "pnpm test && pnpm build && changelogen --release --push && pnpm publish",
31
+ "release": "pnpm test && pnpm build && changelogen --release --prerelease --publish --publishTag rc --push",
46
32
  "test": "pnpm lint && vitest run --coverage",
47
33
  "test:types": "tsc --noEmit"
48
- }
34
+ },
35
+ "devDependencies": {
36
+ "@types/node": "^24.9.1",
37
+ "@vitest/coverage-v8": "^4.0.3",
38
+ "changelogen": "^0.6.2",
39
+ "esbuild": "^0.25.11",
40
+ "eslint": "^9.38.0",
41
+ "eslint-config-unjs": "^0.5.0",
42
+ "expect-type": "^1.2.2",
43
+ "hookable-prev": "npm:hookable@^5.0.0",
44
+ "mitata": "^1.0.34",
45
+ "obuild": "^0.3.0",
46
+ "prettier": "^3.6.2",
47
+ "typescript": "^5.9.3",
48
+ "vite": "^7.1.12",
49
+ "vitest": "^4.0.3"
50
+ },
51
+ "packageManager": "pnpm@10.19.0"
49
52
  }
@@ -1,5 +1,5 @@
1
1
  import { H3Core, toRequest } from "h3";
2
- import { createHooks } from "hookable";
2
+ import { HookableCore } from "hookable";
3
3
  import { nitroAsyncContext } from "./context.mjs";
4
4
  import errorHandler from "#nitro-internal-virtual/error-handler";
5
5
  import { plugins } from "#nitro-internal-virtual/plugins";
@@ -25,9 +25,9 @@ function initNitroApp() {
25
25
  return nitroApp;
26
26
  }
27
27
  function createNitroApp() {
28
- const hooks = createHooks();
28
+ const hooks = new HookableCore();
29
29
  const captureError = (error, errorCtx) => {
30
- const promise = hooks.callHookParallel("error", error, errorCtx).catch((hookError) => {
30
+ const promise = hooks.callHook("error", error, errorCtx)?.catch?.((hookError) => {
31
31
  console.error("Error while capturing another error", hookError);
32
32
  });
33
33
  if (errorCtx?.event) {
@@ -40,20 +40,26 @@ function createNitroApp() {
40
40
  }
41
41
  }
42
42
  };
43
- const h3App = createH3App(captureError);
44
- let fetchHandler = async (req) => {
43
+ const h3App = createH3App({
44
+ onError(error, event) {
45
+ captureError(error, { event });
46
+ return errorHandler(error, event);
47
+ },
48
+ onRequest(event) {
49
+ return hooks.callHook("request", event)?.catch?.((error) => {
50
+ captureError(error, { event, tags: ["request"] });
51
+ });
52
+ },
53
+ onResponse(res, event) {
54
+ return hooks.callHook("response", res, event)?.catch?.((error) => {
55
+ captureError(error, { event, tags: ["response"] });
56
+ });
57
+ }
58
+ });
59
+ let fetchHandler = (req) => {
45
60
  req.context ??= {};
46
61
  req.context.nitro = req.context.nitro || { errors: [] };
47
- const event = { req };
48
- const nitroApp = useNitroApp();
49
- await nitroApp.hooks.callHook("request", event).catch((error) => {
50
- captureError(error, { event, tags: ["request"] });
51
- });
52
- const response = await h3App.request(req, void 0, req.context);
53
- await nitroApp.hooks.callHook("response", response, event).catch((error) => {
54
- captureError(error, { event, tags: ["request", "response"] });
55
- });
56
- return response;
62
+ return h3App.request(req, void 0, req.context);
57
63
  };
58
64
  if (import.meta._asyncContext) {
59
65
  const originalFetchHandler = fetchHandler;
@@ -89,15 +95,8 @@ function createNitroApp() {
89
95
  };
90
96
  return app;
91
97
  }
92
- function createH3App(captureError) {
93
- const DEBUG_MODE = ["1", "true", "TRUE"].includes(process.env.DEBUG + "");
94
- const h3App = new H3Core({
95
- debug: DEBUG_MODE,
96
- onError: (error, event) => {
97
- captureError(error, { event, tags: ["request"] });
98
- return errorHandler(error, event);
99
- }
100
- });
98
+ function createH3App(config) {
99
+ const h3App = new H3Core(config);
101
100
  h3App._findRoute = (event) => findRoute(event.req.method, event.url.pathname);
102
101
  h3App._getMiddleware = (event, route) => {
103
102
  const pathname = event.url.pathname;
@@ -22,7 +22,7 @@ export function setupGracefulShutdown(listener, nitroApp) {
22
22
  console.warn("Graceful shutdown timeout, force exiting...");
23
23
  resolve();
24
24
  }, shutdownConfig.timeout);
25
- nitroApp.hooks.callHook("close").catch((error) => {
25
+ Promise.resolve(nitroApp.hooks.callHook("close")).catch((error) => {
26
26
  console.error(error);
27
27
  }).finally(() => {
28
28
  clearTimeout(timeout);
@@ -1,6 +1,6 @@
1
1
  import { HTTPMethod, HTTPEvent, H3Core, H3EventContext, HTTPHandler, HTTPError, ProxyOptions, Middleware } from 'h3';
2
2
  import { FetchRequest, FetchOptions, FetchResponse } from 'ofetch';
3
- import { Hookable, NestedHooks } from 'hookable';
3
+ import { HookableCore, Hookable, NestedHooks } from 'hookable';
4
4
  import { ServerRequestContext, ServerRequest } from 'srvx';
5
5
  import { Jiti, JitiOptions } from 'jiti';
6
6
  import { Stats } from 'fs';
@@ -147,7 +147,7 @@ interface CachedEventHandlerOptions extends Omit<CacheOptions<ResponseCacheEntry
147
147
 
148
148
  interface NitroApp {
149
149
  _h3?: H3Core;
150
- hooks: Hookable<NitroRuntimeHooks>;
150
+ hooks: HookableCore<NitroRuntimeHooks>;
151
151
  fetch: (req: string | URL | Request, init?: RequestInit, context?: ServerRequestContext | H3EventContext) => Promise<Response>;
152
152
  captureError: CaptureError;
153
153
  }
package/dist/vite.mjs CHANGED
@@ -2,7 +2,6 @@ export { n as nitro } from './_chunks/plugin.mjs';
2
2
  import './_chunks/index.mjs';
3
3
  import 'consola';
4
4
  import 'hookable';
5
- import 'nitro/runtime/meta';
6
5
  import 'node:fs';
7
6
  import 'node:fs/promises';
8
7
  import 'node:url';
@@ -41,6 +40,7 @@ import 'youch';
41
40
  import 'source-map';
42
41
  import 'srvx';
43
42
  import 'klona/full';
43
+ import 'nitro/runtime/meta';
44
44
  import 'node:module';
45
45
  import 'ofetch';
46
46
  import 'klona';
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "nitro-nightly",
3
- "version": "3.1.0-20251025-144733-946505c1",
3
+ "version": "3.1.0-20251026-222805-a13234bf",
4
4
  "description": "Build and Deploy Universal JavaScript Servers",
5
5
  "homepage": "https://nitro.build",
6
6
  "repository": "nitrojs/nitro",
@@ -120,7 +120,7 @@
120
120
  "fs-extra": "^11.3.2",
121
121
  "get-port-please": "^3.2.0",
122
122
  "gzip-size": "^7.0.0",
123
- "hookable": "^5.5.3",
123
+ "hookable": "^6.0.0-rc.1",
124
124
  "httpxy": "^0.1.7",
125
125
  "klona": "^2.0.6",
126
126
  "knitwork": "^1.2.0",
@@ -1,2 +0,0 @@
1
- declare const _default: NitroAppPlugin;
2
- export default _default;
@@ -1,5 +0,0 @@
1
- import { createDebugger } from "hookable";
2
- import { defineNitroPlugin } from "./plugin.mjs";
3
- export default defineNitroPlugin((nitro) => {
4
- createDebugger(nitro.hooks, { tag: "nitro-runtime" });
5
- });