@travetto/transformer 3.0.0-rc.1 → 3.0.0-rc.3

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/package.json CHANGED
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "name": "@travetto/transformer",
3
3
  "displayName": "Transformation",
4
- "version": "3.0.0-rc.1",
4
+ "version": "3.0.0-rc.3",
5
5
  "description": "Functionality for AST transformations, with transformer registration, and general utils",
6
6
  "keywords": [
7
7
  "typescript",
@@ -25,7 +25,7 @@
25
25
  "directory": "module/transformer"
26
26
  },
27
27
  "dependencies": {
28
- "@travetto/base": "^3.0.0-rc.0"
28
+ "@travetto/base": "^3.0.0-rc.1"
29
29
  },
30
30
  "publishConfig": {
31
31
  "access": "public"
@@ -183,7 +183,10 @@ export const TypeBuilder: {
183
183
  const dec = DeclarationUtil.getPrimaryDeclarationNode(member);
184
184
  if (DeclarationUtil.isPublic(dec)) { // If public
185
185
  const memberType = checker.getType(dec);
186
- if (!memberType.getCallSignatures().length) { // if not a function
186
+ if (
187
+ !member.getName().includes('@') && // if not a symbol
188
+ !memberType.getCallSignatures().length // if not a function
189
+ ) {
187
190
  fieldNodes[member.getName()] = memberType;
188
191
  }
189
192
  }
package/src/visitor.ts CHANGED
@@ -40,6 +40,7 @@ export class VisitorFactory<S extends State = State> {
40
40
  #transformers = new Map<TransformerType, TransformerSet<S>>();
41
41
  #logTarget: string;
42
42
  #getState: (context: ts.TransformationContext, src: ts.SourceFile) => S;
43
+ #logger: Console | undefined;
43
44
 
44
45
  constructor(
45
46
  getState: (context: ts.TransformationContext, src: ts.SourceFile) => S,
@@ -78,17 +79,21 @@ export class VisitorFactory<S extends State = State> {
78
79
  }
79
80
  }
80
81
 
82
+ get logger(): Console {
83
+ this.#logger ??= new console.Console({
84
+ stdout: createWriteStream(AppCache.toEntryName(this.#logTarget), { flags: 'a' }),
85
+ inspectOptions: { depth: 4 },
86
+ });
87
+ return this.#logger;
88
+ }
89
+
81
90
  /**
82
91
  * Produce a visitor for a given a file
83
92
  */
84
93
  visitor(): ts.TransformerFactory<ts.SourceFile> {
85
94
  return (context: ts.TransformationContext) => (file: ts.SourceFile): ts.SourceFile => {
86
95
  try {
87
- const c = new console.Console({
88
- stdout: createWriteStream(AppCache.toEntryName(this.#logTarget), { flags: 'a' }),
89
- inspectOptions: { depth: 4 },
90
- });
91
-
96
+ const c = this.logger;
92
97
  ConsoleManager.set({
93
98
  onLog: (level, ctx, args) => c[level](level, ctx, ...LogUtil.collapseNodes(args))
94
99
  });
@@ -120,7 +125,7 @@ export class VisitorFactory<S extends State = State> {
120
125
  if (!(err instanceof Error)) {
121
126
  throw err;
122
127
  }
123
- console.error('Failed transforming', { error: err, file: file.fileName });
128
+ console.error('Failed transforming', { error: `${err.message}\n${err.stack}`, file: file.fileName });
124
129
  const out = new Error(`Failed transforming: ${file.fileName}: ${err.message}`);
125
130
  out.stack = err.stack;
126
131
  throw out;