@ryanatkn/gro 0.136.1 → 0.137.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.
@@ -1 +1 @@
1
- {"version":3,"file":"filer.d.ts","sourceRoot":"../src/lib/","sources":["filer.ts"],"names":[],"mappings":"AAGA,OAAO,KAAK,EAAC,WAAW,EAAC,MAAM,yBAAyB,CAAC;AAGzD,OAAO,KAAK,EAAC,OAAO,EAAC,MAAM,WAAW,CAAC;AACvC,OAAO,EACN,SAAS,EAET,KAAK,cAAc,EACnB,KAAK,OAAO,IAAI,iBAAiB,EAEjC,MAAM,gBAAgB,CAAC;AAUxB,MAAM,WAAW,WAAW;IAC3B,EAAE,EAAE,OAAO,CAAC;IACZ;;;OAGG;IACH,QAAQ,EAAE,MAAM,GAAG,IAAI,CAAC;IACxB,UAAU,EAAE,GAAG,CAAC,OAAO,EAAE,WAAW,CAAC,CAAC;IACtC,YAAY,EAAE,GAAG,CAAC,OAAO,EAAE,WAAW,CAAC,CAAC;CACxC;AAED,MAAM,MAAM,aAAa,GAAG,MAAM,OAAO,CAAC,IAAI,CAAC,CAAC;AAEhD,MAAM,MAAM,eAAe,GAAG,CAAC,MAAM,EAAE,cAAc,EAAE,WAAW,EAAE,WAAW,KAAK,IAAI,CAAC;AAEzF,MAAM,WAAW,OAAO;IACvB,SAAS,CAAC,EAAE,OAAO,SAAS,CAAC;IAC7B,iBAAiB,CAAC,EAAE,OAAO,CAAC,WAAW,CAAC,iBAAiB,EAAE,WAAW,CAAC,CAAC,CAAC;CACzE;AAED,qBAAa,KAAK;;IACjB,KAAK,EAAE,GAAG,CAAC,OAAO,EAAE,WAAW,CAAC,CAAa;gBAKjC,OAAO,GAAE,OAAsB;IAU3C,SAAS,OAAQ,OAAO,KAAG,WAAW,GAAG,SAAS,CAEhD;IAEF,aAAa,OAAQ,OAAO,KAAG,WAAW,CAWxC;IA4HI,KAAK,CAAC,QAAQ,EAAE,eAAe,GAAG,OAAO,CAAC,aAAa,CAAC;IAKxD,KAAK,IAAI,OAAO,CAAC,IAAI,CAAC;CAQ5B"}
1
+ {"version":3,"file":"filer.d.ts","sourceRoot":"../src/lib/","sources":["filer.ts"],"names":[],"mappings":"AAGA,OAAO,KAAK,EAAC,WAAW,EAAC,MAAM,yBAAyB,CAAC;AAGzD,OAAO,KAAK,EAAC,OAAO,EAAC,MAAM,WAAW,CAAC;AACvC,OAAO,EACN,SAAS,EAET,KAAK,cAAc,EACnB,KAAK,OAAO,IAAI,iBAAiB,EAEjC,MAAM,gBAAgB,CAAC;AAUxB,MAAM,WAAW,WAAW;IAC3B,EAAE,EAAE,OAAO,CAAC;IACZ;;;OAGG;IACH,QAAQ,EAAE,MAAM,GAAG,IAAI,CAAC;IACxB,UAAU,EAAE,GAAG,CAAC,OAAO,EAAE,WAAW,CAAC,CAAC;IACtC,YAAY,EAAE,GAAG,CAAC,OAAO,EAAE,WAAW,CAAC,CAAC;CACxC;AAED,MAAM,MAAM,aAAa,GAAG,MAAM,OAAO,CAAC,IAAI,CAAC,CAAC;AAEhD,MAAM,MAAM,eAAe,GAAG,CAAC,MAAM,EAAE,cAAc,EAAE,WAAW,EAAE,WAAW,KAAK,IAAI,CAAC;AAEzF,MAAM,WAAW,OAAO;IACvB,SAAS,CAAC,EAAE,OAAO,SAAS,CAAC;IAC7B,iBAAiB,CAAC,EAAE,OAAO,CAAC,WAAW,CAAC,iBAAiB,EAAE,WAAW,CAAC,CAAC,CAAC;CACzE;AAED,qBAAa,KAAK;;IACjB,KAAK,EAAE,GAAG,CAAC,OAAO,EAAE,WAAW,CAAC,CAAa;gBAKjC,OAAO,GAAE,OAAsB;IAU3C,SAAS,OAAQ,OAAO,KAAG,WAAW,GAAG,SAAS,CAEhD;IAEF,aAAa,OAAQ,OAAO,KAAG,WAAW,CAWxC;IA6HI,KAAK,CAAC,QAAQ,EAAE,eAAe,GAAG,OAAO,CAAC,aAAa,CAAC;IAKxD,KAAK,IAAI,OAAO,CAAC,IAAI,CAAC;CAQ5B"}
package/dist/filer.js CHANGED
@@ -40,44 +40,44 @@ export class Filer {
40
40
  #update(id) {
41
41
  const file = this.get_or_create(id);
42
42
  const new_contents = existsSync(id) ? readFileSync(id, 'utf8') : null;
43
- const contents_changed = file.contents !== new_contents;
43
+ if (file.contents === new_contents) {
44
+ return null;
45
+ }
44
46
  file.contents = new_contents;
45
- if (contents_changed) {
46
- const dir = dirname(file.id);
47
- const dependencies_before = new Set(file.dependencies.keys());
48
- const dependencies_removed = new Set(dependencies_before);
49
- const imported = file.contents ? parse_imports(file.id, file.contents) : [];
50
- for (const specifier of imported) {
51
- // TODO logic is duplicated from loader
52
- const path = map_sveltekit_aliases(specifier, aliases);
53
- // The specifier `path` has now been mapped to its final form, so we can inspect it.
54
- if (path[0] === '.' || path[0] === '/') {
55
- const { path_id } = resolve_specifier(path, dir);
56
- dependencies_removed.delete(path_id);
57
- if (!dependencies_before.has(path_id)) {
58
- const d = this.get_or_create(path_id);
59
- file.dependencies.set(d.id, d);
60
- d.dependents.set(file.id, file);
61
- }
47
+ const dir = dirname(file.id);
48
+ const dependencies_before = new Set(file.dependencies.keys());
49
+ const dependencies_removed = new Set(dependencies_before);
50
+ const imported = file.contents ? parse_imports(file.id, file.contents) : [];
51
+ for (const specifier of imported) {
52
+ // TODO logic is duplicated from loader
53
+ const path = map_sveltekit_aliases(specifier, aliases);
54
+ // The specifier `path` has now been mapped to its final form, so we can inspect it.
55
+ if (path[0] === '.' || path[0] === '/') {
56
+ const { path_id } = resolve_specifier(path, dir);
57
+ dependencies_removed.delete(path_id);
58
+ if (!dependencies_before.has(path_id)) {
59
+ const d = this.get_or_create(path_id);
60
+ file.dependencies.set(d.id, d);
61
+ d.dependents.set(file.id, file);
62
62
  }
63
63
  }
64
- // update any removed dependencies
65
- for (const dependency_removed of dependencies_removed) {
66
- const deleted1 = file.dependencies.delete(dependency_removed);
67
- if (!deleted1)
68
- throw Error('expected to delete1 ' + file.id); // TODO @many delete if correct
69
- const dependency_removed_file = this.get_or_create(dependency_removed);
70
- const deleted2 = dependency_removed_file.dependents.delete(file.id);
71
- if (!deleted2)
72
- throw Error('expected to delete2 ' + file.id); // TODO @many delete if correct
73
- }
64
+ }
65
+ // update any removed dependencies
66
+ for (const dependency_removed of dependencies_removed) {
67
+ const deleted1 = file.dependencies.delete(dependency_removed);
68
+ if (!deleted1)
69
+ throw Error('expected to delete1 ' + file.id); // TODO @many delete if correct
70
+ const dependency_removed_file = this.get_or_create(dependency_removed);
71
+ const deleted2 = dependency_removed_file.dependents.delete(file.id);
72
+ if (!deleted2)
73
+ throw Error('expected to delete2 ' + file.id); // TODO @many delete if correct
74
74
  }
75
75
  return file;
76
76
  }
77
77
  #remove(id) {
78
78
  const file = this.get_by_id(id);
79
79
  if (!file)
80
- return; // this is safe because the object would exist if any other file referenced it as a dependency or dependent
80
+ return null; // this is safe because the object would exist if any other file referenced it as a dependency or dependent
81
81
  file.contents = null; // clear contents in case it gets re-added later, we want the change to be detected
82
82
  let found = false;
83
83
  for (const d of this.files.values()) {
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.136.1',
4
+ version: '0.137.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.136.1',
267
+ version: '0.137.0',
268
268
  modules: {
269
269
  '.': {
270
270
  path: 'index.ts',
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@ryanatkn/gro",
3
- "version": "0.136.1",
3
+ "version": "0.137.0",
4
4
  "description": "task runner and toolkit extending SvelteKit",
5
5
  "motto": "generate, run, optimize",
6
6
  "glyph": "🌰",
package/src/lib/filer.ts CHANGED
@@ -74,51 +74,52 @@ export class Filer {
74
74
  return file;
75
75
  };
76
76
 
77
- #update(id: Path_Id): Source_File {
77
+ #update(id: Path_Id): Source_File | null {
78
78
  const file = this.get_or_create(id);
79
79
  const new_contents = existsSync(id) ? readFileSync(id, 'utf8') : null;
80
- const contents_changed = file.contents !== new_contents;
80
+ if (file.contents === new_contents) {
81
+ return null;
82
+ }
83
+
81
84
  file.contents = new_contents;
82
85
 
83
- if (contents_changed) {
84
- const dir = dirname(file.id);
85
-
86
- const dependencies_before = new Set(file.dependencies.keys());
87
- const dependencies_removed = new Set(dependencies_before);
88
-
89
- const imported = file.contents ? parse_imports(file.id, file.contents) : [];
90
- for (const specifier of imported) {
91
- // TODO logic is duplicated from loader
92
- const path = map_sveltekit_aliases(specifier, aliases);
93
-
94
- // The specifier `path` has now been mapped to its final form, so we can inspect it.
95
- if (path[0] === '.' || path[0] === '/') {
96
- const {path_id} = resolve_specifier(path, dir);
97
- dependencies_removed.delete(path_id);
98
- if (!dependencies_before.has(path_id)) {
99
- const d = this.get_or_create(path_id);
100
- file.dependencies.set(d.id, d);
101
- d.dependents.set(file.id, file);
102
- }
86
+ const dir = dirname(file.id);
87
+
88
+ const dependencies_before = new Set(file.dependencies.keys());
89
+ const dependencies_removed = new Set(dependencies_before);
90
+
91
+ const imported = file.contents ? parse_imports(file.id, file.contents) : [];
92
+ for (const specifier of imported) {
93
+ // TODO logic is duplicated from loader
94
+ const path = map_sveltekit_aliases(specifier, aliases);
95
+
96
+ // The specifier `path` has now been mapped to its final form, so we can inspect it.
97
+ if (path[0] === '.' || path[0] === '/') {
98
+ const {path_id} = resolve_specifier(path, dir);
99
+ dependencies_removed.delete(path_id);
100
+ if (!dependencies_before.has(path_id)) {
101
+ const d = this.get_or_create(path_id);
102
+ file.dependencies.set(d.id, d);
103
+ d.dependents.set(file.id, file);
103
104
  }
104
105
  }
106
+ }
105
107
 
106
- // update any removed dependencies
107
- for (const dependency_removed of dependencies_removed) {
108
- const deleted1 = file.dependencies.delete(dependency_removed);
109
- if (!deleted1) throw Error('expected to delete1 ' + file.id); // TODO @many delete if correct
110
- const dependency_removed_file = this.get_or_create(dependency_removed);
111
- const deleted2 = dependency_removed_file.dependents.delete(file.id);
112
- if (!deleted2) throw Error('expected to delete2 ' + file.id); // TODO @many delete if correct
113
- }
108
+ // update any removed dependencies
109
+ for (const dependency_removed of dependencies_removed) {
110
+ const deleted1 = file.dependencies.delete(dependency_removed);
111
+ if (!deleted1) throw Error('expected to delete1 ' + file.id); // TODO @many delete if correct
112
+ const dependency_removed_file = this.get_or_create(dependency_removed);
113
+ const deleted2 = dependency_removed_file.dependents.delete(file.id);
114
+ if (!deleted2) throw Error('expected to delete2 ' + file.id); // TODO @many delete if correct
114
115
  }
115
116
 
116
117
  return file;
117
118
  }
118
119
 
119
- #remove(id: Path_Id): Source_File | undefined {
120
+ #remove(id: Path_Id): Source_File | null {
120
121
  const file = this.get_by_id(id);
121
- if (!file) return; // this is safe because the object would exist if any other file referenced it as a dependency or dependent
122
+ if (!file) return null; // this is safe because the object would exist if any other file referenced it as a dependency or dependent
122
123
 
123
124
  file.contents = null; // clear contents in case it gets re-added later, we want the change to be detected
124
125
 
@@ -177,7 +178,7 @@ export class Filer {
177
178
 
178
179
  #on_change: Watcher_Change_Callback = (change) => {
179
180
  if (change.is_directory) return;
180
- let source_file: Source_File | undefined;
181
+ let source_file: Source_File | null;
181
182
  switch (change.type) {
182
183
  case 'add':
183
184
  case 'update': {
@@ -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.136.1',
8
+ version: '0.137.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.136.1',
273
+ version: '0.137.0',
274
274
  modules: {
275
275
  '.': {
276
276
  path: 'index.ts',