@ryanatkn/gro 0.137.0 → 0.138.0
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.
- package/dist/gro.config.default.d.ts.map +1 -1
- package/dist/gro.config.default.js +1 -1
- package/dist/package.js +2 -2
- package/dist/plugin.d.ts +2 -2
- package/dist/plugin.d.ts.map +1 -1
- package/dist/plugin.js +3 -5
- package/package.json +1 -1
- package/src/lib/gro.config.default.ts +9 -8
- package/src/lib/package.ts +2 -2
- package/src/lib/plugin.ts +8 -18
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"gro.config.default.d.ts","sourceRoot":"../src/lib/","sources":["gro.config.default.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAC,iBAAiB,EAAC,MAAM,iBAAiB,CAAC;AAOvD;;;;;;;;GAQG;AACH,QAAA,MAAM,MAAM,EAAE,
|
|
1
|
+
{"version":3,"file":"gro.config.default.d.ts","sourceRoot":"../src/lib/","sources":["gro.config.default.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAC,iBAAiB,EAAC,MAAM,iBAAiB,CAAC;AAOvD;;;;;;;;GAQG;AACH,QAAA,MAAM,MAAM,EAAE,iBAeb,CAAC;AAEF,eAAe,MAAM,CAAC"}
|
package/dist/package.js
CHANGED
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
// generated by src/lib/package.gen.ts
|
|
2
2
|
export const package_json = {
|
|
3
3
|
name: '@ryanatkn/gro',
|
|
4
|
-
version: '0.
|
|
4
|
+
version: '0.138.0',
|
|
5
5
|
description: 'task runner and toolkit extending SvelteKit',
|
|
6
6
|
motto: 'generate, run, optimize',
|
|
7
7
|
glyph: '🌰',
|
|
@@ -264,7 +264,7 @@ export const package_json = {
|
|
|
264
264
|
};
|
|
265
265
|
export const src_json = {
|
|
266
266
|
name: '@ryanatkn/gro',
|
|
267
|
-
version: '0.
|
|
267
|
+
version: '0.138.0',
|
|
268
268
|
modules: {
|
|
269
269
|
'.': {
|
|
270
270
|
path: 'index.ts',
|
package/dist/plugin.d.ts
CHANGED
|
@@ -9,7 +9,7 @@ export interface Plugin<T_Plugin_Context extends Plugin_Context = Plugin_Context
|
|
|
9
9
|
adapt?: (ctx: T_Plugin_Context) => void | Promise<void>;
|
|
10
10
|
teardown?: (ctx: T_Plugin_Context) => void | Promise<void>;
|
|
11
11
|
}
|
|
12
|
-
export type Create_Config_Plugins<T_Plugin_Context extends Plugin_Context = Plugin_Context> = (ctx: T_Plugin_Context) =>
|
|
12
|
+
export type Create_Config_Plugins<T_Plugin_Context extends Plugin_Context = Plugin_Context> = (ctx: T_Plugin_Context) => Array<Plugin<T_Plugin_Context>> | Promise<Array<Plugin<T_Plugin_Context>>>;
|
|
13
13
|
export interface Plugin_Context<T_Args = object> extends Task_Context<T_Args> {
|
|
14
14
|
dev: boolean;
|
|
15
15
|
watch: boolean;
|
|
@@ -31,5 +31,5 @@ export declare class Plugins<T_Plugin_Context extends Plugin_Context> {
|
|
|
31
31
|
* @param name - @default new_plugin.name
|
|
32
32
|
* @returns `plugins` with `new_plugin` at the index of the plugin with `name`
|
|
33
33
|
*/
|
|
34
|
-
export declare const replace_plugin:
|
|
34
|
+
export declare const replace_plugin: (plugins: Plugin[], new_plugin: Plugin, name?: string) => Plugin[];
|
|
35
35
|
//# sourceMappingURL=plugin.d.ts.map
|
package/dist/plugin.d.ts.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"plugin.d.ts","sourceRoot":"../src/lib/","sources":["plugin.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"plugin.d.ts","sourceRoot":"../src/lib/","sources":["plugin.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAC,YAAY,EAAC,MAAM,WAAW,CAAC;AAE5C;;;GAGG;AACH,MAAM,WAAW,MAAM,CAAC,gBAAgB,SAAS,cAAc,GAAG,cAAc;IAC/E,IAAI,EAAE,MAAM,CAAC;IACb,KAAK,CAAC,EAAE,CAAC,GAAG,EAAE,gBAAgB,KAAK,IAAI,GAAG,OAAO,CAAC,IAAI,CAAC,CAAC;IACxD,KAAK,CAAC,EAAE,CAAC,GAAG,EAAE,gBAAgB,KAAK,IAAI,GAAG,OAAO,CAAC,IAAI,CAAC,CAAC;IACxD,QAAQ,CAAC,EAAE,CAAC,GAAG,EAAE,gBAAgB,KAAK,IAAI,GAAG,OAAO,CAAC,IAAI,CAAC,CAAC;CAC3D;AAED,MAAM,MAAM,qBAAqB,CAAC,gBAAgB,SAAS,cAAc,GAAG,cAAc,IAAI,CAC7F,GAAG,EAAE,gBAAgB,KACjB,KAAK,CAAC,MAAM,CAAC,gBAAgB,CAAC,CAAC,GAAG,OAAO,CAAC,KAAK,CAAC,MAAM,CAAC,gBAAgB,CAAC,CAAC,CAAC,CAAC;AAEhF,MAAM,WAAW,cAAc,CAAC,MAAM,GAAG,MAAM,CAAE,SAAQ,YAAY,CAAC,MAAM,CAAC;IAC5E,GAAG,EAAE,OAAO,CAAC;IACb,KAAK,EAAE,OAAO,CAAC;CACf;AAED,qBAAa,OAAO,CAAC,gBAAgB,SAAS,cAAc;IAG1D,OAAO,CAAC,GAAG;IACX,OAAO,CAAC,SAAS;gBADT,GAAG,EAAE,gBAAgB,EACrB,SAAS,EAAE,MAAM,EAAE;WAGf,MAAM,CAAC,gBAAgB,SAAS,cAAc,EAC1D,GAAG,EAAE,gBAAgB,GACnB,OAAO,CAAC,OAAO,CAAC,gBAAgB,CAAC,CAAC;IAS/B,KAAK,IAAI,OAAO,CAAC,IAAI,CAAC;IAetB,KAAK,IAAI,OAAO,CAAC,IAAI,CAAC;IAatB,QAAQ,IAAI,OAAO,CAAC,IAAI,CAAC;CAc/B;AAED;;;;;;;GAOG;AACH,eAAO,MAAM,cAAc,YACjB,MAAM,EAAE,cACL,MAAM,oBAEhB,MAAM,EAMR,CAAC"}
|
package/dist/plugin.js
CHANGED
|
@@ -1,4 +1,3 @@
|
|
|
1
|
-
import { to_array } from '@ryanatkn/belt/array.js';
|
|
2
1
|
export class Plugins {
|
|
3
2
|
ctx;
|
|
4
3
|
instances;
|
|
@@ -10,7 +9,7 @@ export class Plugins {
|
|
|
10
9
|
static async create(ctx) {
|
|
11
10
|
const { timings } = ctx;
|
|
12
11
|
const timing_to_create = timings.start('plugins.create');
|
|
13
|
-
const instances =
|
|
12
|
+
const instances = await ctx.config.plugins(ctx);
|
|
14
13
|
const plugins = new Plugins(ctx, instances);
|
|
15
14
|
timing_to_create();
|
|
16
15
|
return plugins;
|
|
@@ -70,11 +69,10 @@ export class Plugins {
|
|
|
70
69
|
* @returns `plugins` with `new_plugin` at the index of the plugin with `name`
|
|
71
70
|
*/
|
|
72
71
|
export const replace_plugin = (plugins, new_plugin, name = new_plugin.name) => {
|
|
73
|
-
const
|
|
74
|
-
const index = array.findIndex((p) => p.name === name);
|
|
72
|
+
const index = plugins.findIndex((p) => p.name === name);
|
|
75
73
|
if (index === -1)
|
|
76
74
|
throw Error('Failed to find plugin to replace: ' + name);
|
|
77
|
-
const replaced =
|
|
75
|
+
const replaced = plugins.slice();
|
|
78
76
|
replaced[index] = new_plugin;
|
|
79
77
|
return replaced;
|
|
80
78
|
};
|
package/package.json
CHANGED
|
@@ -18,14 +18,15 @@ const config: Create_Gro_Config = async (cfg) => {
|
|
|
18
18
|
const [has_sveltekit_library_result, has_server_result, has_sveltekit_app_result] =
|
|
19
19
|
await Promise.all([has_sveltekit_library(), has_server(), has_sveltekit_app()]);
|
|
20
20
|
|
|
21
|
-
cfg.plugins = () =>
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
21
|
+
cfg.plugins = () =>
|
|
22
|
+
[
|
|
23
|
+
has_sveltekit_library_result.ok ? gro_plugin_sveltekit_library() : null,
|
|
24
|
+
has_server_result.ok ? gro_plugin_server() : null,
|
|
25
|
+
has_sveltekit_app_result.ok
|
|
26
|
+
? gro_plugin_sveltekit_app({host_target: has_server_result.ok ? 'node' : 'github_pages'})
|
|
27
|
+
: null,
|
|
28
|
+
gro_plugin_gen(),
|
|
29
|
+
].filter((v) => v !== null);
|
|
29
30
|
|
|
30
31
|
return cfg;
|
|
31
32
|
};
|
package/src/lib/package.ts
CHANGED
|
@@ -5,7 +5,7 @@ import type {Src_Json} from './src_json.js';
|
|
|
5
5
|
|
|
6
6
|
export const package_json = {
|
|
7
7
|
name: '@ryanatkn/gro',
|
|
8
|
-
version: '0.
|
|
8
|
+
version: '0.138.0',
|
|
9
9
|
description: 'task runner and toolkit extending SvelteKit',
|
|
10
10
|
motto: 'generate, run, optimize',
|
|
11
11
|
glyph: '🌰',
|
|
@@ -270,7 +270,7 @@ export const package_json = {
|
|
|
270
270
|
|
|
271
271
|
export const src_json = {
|
|
272
272
|
name: '@ryanatkn/gro',
|
|
273
|
-
version: '0.
|
|
273
|
+
version: '0.138.0',
|
|
274
274
|
modules: {
|
|
275
275
|
'.': {
|
|
276
276
|
path: 'index.ts',
|
package/src/lib/plugin.ts
CHANGED
|
@@ -1,5 +1,3 @@
|
|
|
1
|
-
import {to_array} from '@ryanatkn/belt/array.js';
|
|
2
|
-
|
|
3
1
|
import type {Task_Context} from './task.js';
|
|
4
2
|
|
|
5
3
|
/**
|
|
@@ -15,9 +13,7 @@ export interface Plugin<T_Plugin_Context extends Plugin_Context = Plugin_Context
|
|
|
15
13
|
|
|
16
14
|
export type Create_Config_Plugins<T_Plugin_Context extends Plugin_Context = Plugin_Context> = (
|
|
17
15
|
ctx: T_Plugin_Context,
|
|
18
|
-
) =>
|
|
19
|
-
| (Plugin<T_Plugin_Context> | null | Array<Plugin<T_Plugin_Context> | null>)
|
|
20
|
-
| Promise<Plugin<T_Plugin_Context> | null | Array<Plugin<T_Plugin_Context> | null>>;
|
|
16
|
+
) => Array<Plugin<T_Plugin_Context>> | Promise<Array<Plugin<T_Plugin_Context>>>;
|
|
21
17
|
|
|
22
18
|
export interface Plugin_Context<T_Args = object> extends Task_Context<T_Args> {
|
|
23
19
|
dev: boolean;
|
|
@@ -36,9 +32,7 @@ export class Plugins<T_Plugin_Context extends Plugin_Context> {
|
|
|
36
32
|
): Promise<Plugins<T_Plugin_Context>> {
|
|
37
33
|
const {timings} = ctx;
|
|
38
34
|
const timing_to_create = timings.start('plugins.create');
|
|
39
|
-
const instances: Plugin[] =
|
|
40
|
-
(v) => v !== null,
|
|
41
|
-
) as Plugin[]; // TODO remove cast, should infer the type predicate? `Type '(Plugin<Plugin_Context<object>> | null)[]' is not assignable to type 'Plugin<Plugin_Context<object>>[]'.`
|
|
35
|
+
const instances: Plugin[] = await ctx.config.plugins(ctx);
|
|
42
36
|
const plugins = new Plugins(ctx, instances);
|
|
43
37
|
timing_to_create();
|
|
44
38
|
return plugins;
|
|
@@ -96,18 +90,14 @@ export class Plugins<T_Plugin_Context extends Plugin_Context> {
|
|
|
96
90
|
* @param name - @default new_plugin.name
|
|
97
91
|
* @returns `plugins` with `new_plugin` at the index of the plugin with `name`
|
|
98
92
|
*/
|
|
99
|
-
export const replace_plugin =
|
|
100
|
-
|
|
101
|
-
T_Plugin extends Plugin,
|
|
102
|
-
>(
|
|
103
|
-
plugins: T_Plugins,
|
|
93
|
+
export const replace_plugin = (
|
|
94
|
+
plugins: Plugin[],
|
|
104
95
|
new_plugin: Plugin,
|
|
105
96
|
name = new_plugin.name,
|
|
106
|
-
):
|
|
107
|
-
const
|
|
108
|
-
const index = array.findIndex((p) => p.name === name);
|
|
97
|
+
): Plugin[] => {
|
|
98
|
+
const index = plugins.findIndex((p) => p.name === name);
|
|
109
99
|
if (index === -1) throw Error('Failed to find plugin to replace: ' + name);
|
|
110
|
-
const replaced =
|
|
100
|
+
const replaced = plugins.slice();
|
|
111
101
|
replaced[index] = new_plugin;
|
|
112
|
-
return replaced
|
|
102
|
+
return replaced;
|
|
113
103
|
};
|