@trpc/upgrade 0.0.0-alpha.0 → 0.0.0-alpha.1

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/cli.cjs CHANGED
@@ -4,13 +4,11 @@ var cli$1 = require('@effect/cli');
4
4
  var platform = require('@effect/platform');
5
5
  var platformNode = require('@effect/platform-node');
6
6
  var effect = require('effect');
7
- var ignore = require('ignore');
8
7
  var typescript = require('typescript');
9
8
 
10
9
  function _interopDefault (e) { return e && e.__esModule ? e : { default: e }; }
11
10
 
12
11
  var path__default = /*#__PURE__*/_interopDefault(path);
13
- var ignore__default = /*#__PURE__*/_interopDefault(ignore);
14
12
 
15
13
  var version = "0.0.0-alpha.0";
16
14
 
@@ -20,12 +18,15 @@ const installPackage = (packageName)=>{
20
18
  return platform.Command.streamLines(platform.Command.make(packageManager, 'install', packageName)).pipe(effect.Stream.mapEffect(effect.Console.log), effect.Stream.runDrain);
21
19
  };
22
20
  const filterIgnored = (files)=>effect.Effect.gen(function*() {
23
- const fs = yield* platform.FileSystem.FileSystem;
24
- const ignores = yield* fs.readFileString(path__default.default.join(process.cwd(), '.gitignore')).pipe(effect.Effect.map((content)=>content.split('\n')), effect.Effect.map((patterns)=>ignore__default.default().add(patterns)));
21
+ const ignores = yield* platform.Command.string(platform.Command.make('git', 'check-ignore', '**/*')).pipe(effect.Effect.map((_)=>_.split('\n')));
22
+ yield* effect.Effect.log('All files in program:', files.map((_)=>_.fileName));
23
+ yield* effect.Effect.log('Ignored files:', ignores);
25
24
  // Ignore "common files"
26
- const relativeFilePaths = files.filter((source)=>!source.fileName.includes('node_modules') && !source.fileName.includes('packages/')).map((file)=>path__default.default.relative(process.cwd(), file.fileName));
27
- // As well as gitignored?
28
- return ignores.filter(relativeFilePaths);
25
+ const filteredSourcePaths = files.filter((source)=>source.fileName.startsWith(path__default.default.resolve()) && // only look ahead of current directory
26
+ !source.fileName.includes('/trpc/packages/') && // relative paths when running codemod locally
27
+ !ignores.includes(source.fileName)).map((source)=>source.fileName);
28
+ yield* effect.Effect.log('Filtered files:', filteredSourcePaths);
29
+ return filteredSourcePaths;
29
30
  });
30
31
  const Program = effect.Effect.succeed(typescript.findConfigFile(process.cwd(), typescript.sys.fileExists)).pipe(effect.Effect.filterOrFail(effect.Predicate.isNotNullable, ()=>'No tsconfig found'), effect.Effect.tap((_)=>effect.Effect.logDebug('Using tsconfig', _)), effect.Effect.map((_)=>typescript.readConfigFile(_, typescript.sys.readFile)), effect.Effect.map((_)=>typescript.parseJsonConfigFileContent(_.config, typescript.sys, process.cwd())), effect.Effect.map((_)=>typescript.createProgram({
31
32
  options: _.options,
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@trpc/upgrade",
3
- "version": "0.0.0-alpha.0",
3
+ "version": "0.0.0-alpha.1",
4
4
  "description": "Upgrade scripts for tRPC",
5
5
  "author": "juliusmarminge",
6
6
  "license": "MIT",
@@ -32,7 +32,6 @@
32
32
  "@effect/platform": "0.69.25",
33
33
  "@effect/platform-node": "0.64.27",
34
34
  "effect": "3.10.16",
35
- "ignore": "^6.0.2",
36
35
  "jscodeshift": "17.1.1",
37
36
  "typescript": "^5.6.2"
38
37
  },
package/src/bin/cli.ts CHANGED
@@ -1,7 +1,7 @@
1
1
  /* eslint-disable @typescript-eslint/unbound-method */
2
2
  import path from 'path';
3
3
  import { Command as CLICommand, Prompt } from '@effect/cli';
4
- import { Command, FileSystem } from '@effect/platform';
4
+ import { Command } from '@effect/platform';
5
5
  import { NodeContext, NodeRuntime } from '@effect/platform-node';
6
6
  import {
7
7
  Console,
@@ -12,7 +12,6 @@ import {
12
12
  Stream,
13
13
  String,
14
14
  } from 'effect';
15
- import ignore from 'ignore';
16
15
  import type { SourceFile } from 'typescript';
17
16
  import {
18
17
  createProgram,
@@ -47,25 +46,29 @@ const installPackage = (packageName: string) => {
47
46
 
48
47
  const filterIgnored = (files: readonly SourceFile[]) =>
49
48
  Effect.gen(function* () {
50
- const fs = yield* FileSystem.FileSystem;
51
- const ignores = yield* fs
52
- .readFileString(path.join(process.cwd(), '.gitignore'))
53
- .pipe(
54
- Effect.map((content) => content.split('\n')),
55
- Effect.map((patterns) => ignore().add(patterns)),
56
- );
49
+ const ignores = yield* Command.string(
50
+ Command.make('git', 'check-ignore', '**/*'),
51
+ ).pipe(Effect.map((_) => _.split('\n')));
52
+
53
+ yield* Effect.log(
54
+ 'All files in program:',
55
+ files.map((_) => _.fileName),
56
+ );
57
+ yield* Effect.log('Ignored files:', ignores);
57
58
 
58
59
  // Ignore "common files"
59
- const relativeFilePaths = files
60
+ const filteredSourcePaths = files
60
61
  .filter(
61
62
  (source) =>
62
- !source.fileName.includes('node_modules') &&
63
- !source.fileName.includes('packages/'),
63
+ source.fileName.startsWith(path.resolve()) && // only look ahead of current directory
64
+ !source.fileName.includes('/trpc/packages/') && // relative paths when running codemod locally
65
+ !ignores.includes(source.fileName), // ignored files
64
66
  )
65
- .map((file) => path.relative(process.cwd(), file.fileName));
67
+ .map((source) => source.fileName);
68
+
69
+ yield* Effect.log('Filtered files:', filteredSourcePaths);
66
70
 
67
- // As well as gitignored?
68
- return ignores.filter(relativeFilePaths);
71
+ return filteredSourcePaths;
69
72
  });
70
73
 
71
74
  const Program = Effect.succeed(