@player-tools/complexity-check-plugin 0.9.1-next.2 → 0.10.0-next.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.
@@ -68,7 +68,7 @@ var ComplexityCheck = class {
68
68
  const message = `Content complexity is ${this.contentScore}`;
69
69
  let diagnostic = {
70
70
  message: `${message}`,
71
- severity: import_vscode_languageserver_types.DiagnosticSeverity.Information,
71
+ severity: import_vscode_languageserver_types.DiagnosticSeverity.Hint,
72
72
  range: diagnosticRange
73
73
  };
74
74
  if (this.contentScore < this.config.maxAcceptableComplexity) {
@@ -100,14 +100,14 @@ var ComplexityCheck = class {
100
100
  this.contentScore += numExp.valueNode.children.length * this.scoreCriteria.expInActionState;
101
101
  this.verboseDetails.push({
102
102
  message: `state exp (+${this.scoreCriteria.expInActionState} x ${numExp.valueNode.children.length}): ${this.contentScore}`,
103
- severity: import_vscode_languageserver_types.DiagnosticSeverity.Information,
103
+ severity: import_vscode_languageserver_types.DiagnosticSeverity.Hint,
104
104
  range: (0, import_json_language_service.toRange)(ctx.document, flowState)
105
105
  });
106
106
  } else {
107
107
  this.contentScore += this.scoreCriteria.expInActionState;
108
108
  this.verboseDetails.push({
109
109
  message: `state exp (+${this.scoreCriteria.expInActionState}): ${this.contentScore}`,
110
- severity: import_vscode_languageserver_types.DiagnosticSeverity.Information,
110
+ severity: import_vscode_languageserver_types.DiagnosticSeverity.Hint,
111
111
  range: (0, import_json_language_service.toRange)(ctx.document, flowState)
112
112
  });
113
113
  }
@@ -121,7 +121,7 @@ var ComplexityCheck = class {
121
121
  this.contentScore += this.scoreCriteria.template;
122
122
  this.verboseDetails.push({
123
123
  message: `found a template parent (+${this.scoreCriteria.template}): ${this.contentScore}`,
124
- severity: import_vscode_languageserver_types.DiagnosticSeverity.Information,
124
+ severity: import_vscode_languageserver_types.DiagnosticSeverity.Hint,
125
125
  range: (0, import_json_language_service.toRange)(ctx.document, assetNode)
126
126
  });
127
127
  return checkParentTemplate(node.parent);
@@ -146,20 +146,20 @@ var ComplexityCheck = class {
146
146
  }
147
147
  this.verboseDetails.push({
148
148
  message: `assetNode (${this.scoreCriteria.assetNode} +${typeWeights} for ${assetType}): ${this.contentScore}`,
149
- severity: import_vscode_languageserver_types.DiagnosticSeverity.Information,
149
+ severity: import_vscode_languageserver_types.DiagnosticSeverity.Hint,
150
150
  range: (0, import_json_language_service.toRange)(ctx.document, assetNode)
151
151
  });
152
152
  } else {
153
153
  this.verboseDetails.push({
154
154
  message: `assetNode (+${this.scoreCriteria.assetNode} - ${assetType} complexity type not found): ${this.contentScore}`,
155
- severity: import_vscode_languageserver_types.DiagnosticSeverity.Information,
155
+ severity: import_vscode_languageserver_types.DiagnosticSeverity.Hint,
156
156
  range: (0, import_json_language_service.toRange)(ctx.document, assetNode)
157
157
  });
158
158
  }
159
159
  } else
160
160
  this.verboseDetails.push({
161
161
  message: `assetNode (+${this.scoreCriteria.assetNode}): ${this.contentScore}`,
162
- severity: import_vscode_languageserver_types.DiagnosticSeverity.Information,
162
+ severity: import_vscode_languageserver_types.DiagnosticSeverity.Hint,
163
163
  range: (0, import_json_language_service.toRange)(ctx.document, assetNode)
164
164
  });
165
165
  },
@@ -179,20 +179,20 @@ var ComplexityCheck = class {
179
179
  }
180
180
  this.verboseDetails.push({
181
181
  message: `viewNode (${this.scoreCriteria.viewNode} +${viewComplexity} for ${viewType}): ${this.contentScore}`,
182
- severity: import_vscode_languageserver_types.DiagnosticSeverity.Information,
182
+ severity: import_vscode_languageserver_types.DiagnosticSeverity.Hint,
183
183
  range: (0, import_json_language_service.toRange)(ctx.document, viewNode)
184
184
  });
185
185
  } else {
186
186
  this.verboseDetails.push({
187
187
  message: `viewNode (+${this.scoreCriteria.viewNode} - ${viewType} complexity type not found): ${this.contentScore}`,
188
- severity: import_vscode_languageserver_types.DiagnosticSeverity.Information,
188
+ severity: import_vscode_languageserver_types.DiagnosticSeverity.Hint,
189
189
  range: (0, import_json_language_service.toRange)(ctx.document, viewNode)
190
190
  });
191
191
  }
192
192
  } else
193
193
  this.verboseDetails.push({
194
194
  message: `viewNode (+${this.scoreCriteria.viewNode}): ${this.contentScore}`,
195
- severity: import_vscode_languageserver_types.DiagnosticSeverity.Information,
195
+ severity: import_vscode_languageserver_types.DiagnosticSeverity.Hint,
196
196
  range: (0, import_json_language_service.toRange)(ctx.document, viewNode)
197
197
  });
198
198
  },
@@ -204,7 +204,7 @@ var ComplexityCheck = class {
204
204
  this.contentScore += this.scoreCriteria.modelGet;
205
205
  this.verboseDetails.push({
206
206
  message: `model - get: ${binding} (+${this.scoreCriteria.modelGet}): ${this.contentScore}`,
207
- severity: import_vscode_languageserver_types.DiagnosticSeverity.Information,
207
+ severity: import_vscode_languageserver_types.DiagnosticSeverity.Hint,
208
208
  range: (0, import_json_language_service.toRange)(ctx.document, stringNode)
209
209
  });
210
210
  return binding;
@@ -213,7 +213,7 @@ var ComplexityCheck = class {
213
213
  this.contentScore += this.scoreCriteria.modelSet;
214
214
  this.verboseDetails.push({
215
215
  message: `model - set: ${binding} (+${this.scoreCriteria.modelSet}: ${this.contentScore}`,
216
- severity: import_vscode_languageserver_types.DiagnosticSeverity.Information,
216
+ severity: import_vscode_languageserver_types.DiagnosticSeverity.Hint,
217
217
  range: (0, import_json_language_service.toRange)(ctx.document, stringNode)
218
218
  });
219
219
  return [];
@@ -225,7 +225,7 @@ var ComplexityCheck = class {
225
225
  this.contentScore += this.scoreCriteria.modelEvaluate;
226
226
  this.verboseDetails.push({
227
227
  message: `model - evaluate: ${str} (+${this.scoreCriteria.modelEvaluate}): ${this.contentScore}`,
228
- severity: import_vscode_languageserver_types.DiagnosticSeverity.Information,
228
+ severity: import_vscode_languageserver_types.DiagnosticSeverity.Hint,
229
229
  range: (0, import_json_language_service.toRange)(ctx.document, stringNode)
230
230
  });
231
231
  return str;
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../../../../../../../../../../execroot/_main/bazel-out/k8-fastbuild/bin/language/complexity-check-plugin/src/index.ts","../../../../../../../../../../../../execroot/_main/bazel-out/k8-fastbuild/bin/language/complexity-check-plugin/src/complexity-check.ts"],"sourcesContent":["export * from \"./complexity-check\";\n","import { Diagnostic, DiagnosticSeverity } from \"vscode-languageserver-types\";\nimport { resolveDataRefs } from \"@player-ui/player\";\nimport {\n getProperty,\n isPropertyNode,\n AssetASTNode,\n toRange,\n} from \"@player-tools/json-language-service\";\nimport type {\n ASTNode,\n ASTVisitor,\n PlayerLanguageService,\n PlayerLanguageServicePlugin,\n ViewASTNode,\n DocumentContext,\n} from \"@player-tools/json-language-service\";\n\nconst BASE_WEIGHTS = {\n expInActionState: 1,\n assetNode: 1,\n viewNode: 1,\n template: 1,\n modelGet: 4,\n modelSet: 4,\n modelEvaluate: 4,\n};\n\nexport interface ComplexityCheckConfig {\n /** Cutoff for content to be acceptable */\n maxAcceptableComplexity: number;\n /**\n * If set, any score above this number but below `maxAcceptableComplexity` will be logged as a warning\n */\n maxWarningLevel?: number;\n /** If set, maps additional complexity based on asset or view type */\n typeWeights?: Record<string, number>;\n /** If set, assign override values for the keys specified from baseWeights */\n baseWeightOverrides?: Partial<Record<keyof typeof BASE_WEIGHTS, number>>;\n}\n\n/**\n * Estimates complexity of content\n */\nexport class ComplexityCheck implements PlayerLanguageServicePlugin {\n name = \"complexity-check\";\n\n private config: ComplexityCheckConfig;\n private typeCount: Record<string, number>;\n private contentScore: number;\n private verboseDetails: Diagnostic[];\n private scoreCriteria: Record<string, number>;\n\n constructor(config: ComplexityCheckConfig) {\n this.config = config;\n this.typeCount = {};\n this.contentScore = 0;\n this.verboseDetails = [];\n this.scoreCriteria = { ...BASE_WEIGHTS, ...config.baseWeightOverrides };\n }\n\n apply(service: PlayerLanguageService): void {\n service.hooks.validate.tap(this.name, async (ctx, validation) => {\n validation.useASTVisitor(this.createContentChecker(ctx));\n });\n\n service.hooks.onDocumentUpdate.tap(this.name, () => {\n this.typeCount = {};\n this.contentScore = 0;\n this.verboseDetails = [];\n });\n\n service.hooks.onValidateEnd.tap(this.name, (diagnostics) => {\n const diagnosticRange = {\n start: { line: 0, character: 0 },\n end: { line: 0, character: 0 },\n };\n\n const message = `Content complexity is ${this.contentScore}`;\n\n let diagnostic: Diagnostic = {\n message: `${message}`,\n severity: DiagnosticSeverity.Information,\n range: diagnosticRange,\n };\n\n if (this.contentScore < this.config.maxAcceptableComplexity) {\n if (\n this.config.maxWarningLevel &&\n this.contentScore > this.config.maxWarningLevel\n ) {\n diagnostic = {\n message: `${message}, Warning: ${this.config.maxWarningLevel}`,\n severity: DiagnosticSeverity.Warning,\n range: diagnosticRange,\n };\n }\n } else {\n diagnostic = {\n message: `${message}, Maximum: ${this.config.maxAcceptableComplexity}`,\n severity: DiagnosticSeverity.Error,\n range: diagnosticRange,\n };\n }\n\n return [diagnostic, ...diagnostics, ...this.verboseDetails];\n });\n }\n\n /** Create a validation visitor for dealing with transition states */\n createContentChecker = (ctx: DocumentContext): ASTVisitor => {\n return {\n FlowStateNode: (flowState) => {\n // Add complexity per expression in a state\n if (flowState.stateType) {\n if (flowState.stateType.valueNode?.value === \"ACTION\") {\n const numExp = getProperty(flowState, \"exp\");\n if (numExp?.valueNode?.type === \"array\") {\n this.contentScore +=\n numExp.valueNode.children.length *\n this.scoreCriteria.expInActionState;\n\n this.verboseDetails.push({\n message: `state exp (+${this.scoreCriteria.expInActionState} x ${numExp.valueNode.children.length}): ${this.contentScore}`,\n severity: DiagnosticSeverity.Information,\n range: toRange(ctx.document, flowState),\n });\n } else {\n this.contentScore += this.scoreCriteria.expInActionState;\n\n this.verboseDetails.push({\n message: `state exp (+${this.scoreCriteria.expInActionState}): ${this.contentScore}`,\n severity: DiagnosticSeverity.Information,\n range: toRange(ctx.document, flowState),\n });\n }\n }\n }\n },\n AssetNode: (assetNode: AssetASTNode) => {\n // Recursively check parent nodes for templates\n const checkParentTemplate = (node: ASTNode) => {\n if (node.parent) {\n if (\n isPropertyNode(node.parent) &&\n node.parent.keyNode.value === \"template\"\n ) {\n // Increase the template count each time it finds a nested template\n\n this.contentScore += this.scoreCriteria.template;\n\n this.verboseDetails.push({\n message: `found a template parent (+${this.scoreCriteria.template}): ${this.contentScore}`,\n severity: DiagnosticSeverity.Information,\n range: toRange(ctx.document, assetNode),\n });\n\n return checkParentTemplate(node.parent);\n }\n return checkParentTemplate(node.parent);\n }\n return node;\n };\n\n checkParentTemplate(assetNode);\n this.contentScore += this.scoreCriteria.assetNode;\n\n const assetType = assetNode.assetType?.valueNode?.value;\n\n // Map the typeWeights score based on the asset type\n const typeWeights = assetType\n ? this.config.typeWeights?.[assetType]\n : undefined;\n\n // Only run if typeWeights is set in the config\n if (this.config.typeWeights) {\n if (typeWeights) {\n this.contentScore += typeWeights;\n if (assetType) {\n // If an assetType is found, add 1 point to typeCount for each occurrence\n if (this.typeCount[assetType] !== undefined) {\n this.typeCount[assetType] += 1;\n } else {\n this.typeCount[assetType] = 1;\n }\n }\n this.verboseDetails.push({\n message: `assetNode (${this.scoreCriteria.assetNode} +${typeWeights} for ${assetType}): ${this.contentScore}`,\n severity: DiagnosticSeverity.Information,\n range: toRange(ctx.document, assetNode),\n });\n } else {\n this.verboseDetails.push({\n message: `assetNode (+${this.scoreCriteria.assetNode} - ${assetType} complexity type not found): ${this.contentScore}`,\n severity: DiagnosticSeverity.Information,\n range: toRange(ctx.document, assetNode),\n });\n }\n } else\n this.verboseDetails.push({\n message: `assetNode (+${this.scoreCriteria.assetNode}): ${this.contentScore}`,\n severity: DiagnosticSeverity.Information,\n range: toRange(ctx.document, assetNode),\n });\n },\n ViewNode: (viewNode: ViewASTNode) => {\n this.contentScore += this.scoreCriteria.viewNode;\n\n const viewType = viewNode.viewType?.valueNode?.value;\n\n // Map the typeWeights score based on the view type\n const viewComplexity = viewType\n ? this.config.typeWeights?.[viewType]\n : undefined;\n\n // Only run if typeWeights is set in the config\n if (this.config.typeWeights) {\n if (viewComplexity) {\n this.contentScore += viewComplexity;\n\n if (viewType) {\n // If a viewType is found, add 1 point to typeCount for each occurrence\n if (this.typeCount[viewType] !== undefined) {\n this.typeCount[viewType] += 1;\n } else {\n this.typeCount[viewType] = 1;\n }\n }\n this.verboseDetails.push({\n message: `viewNode (${this.scoreCriteria.viewNode} +${viewComplexity} for ${viewType}): ${this.contentScore}`,\n severity: DiagnosticSeverity.Information,\n range: toRange(ctx.document, viewNode),\n });\n } else {\n this.verboseDetails.push({\n message: `viewNode (+${this.scoreCriteria.viewNode} - ${viewType} complexity type not found): ${this.contentScore}`,\n severity: DiagnosticSeverity.Information,\n range: toRange(ctx.document, viewNode),\n });\n }\n } else\n this.verboseDetails.push({\n message: `viewNode (+${this.scoreCriteria.viewNode}): ${this.contentScore}`,\n severity: DiagnosticSeverity.Information,\n range: toRange(ctx.document, viewNode),\n });\n },\n StringNode: (stringNode) => {\n const stringContent = stringNode.value;\n resolveDataRefs(stringContent, {\n model: {\n get: (binding) => {\n this.contentScore += this.scoreCriteria.modelGet;\n\n this.verboseDetails.push({\n message: `model - get: ${binding} (+${this.scoreCriteria.modelGet}): ${this.contentScore}`,\n severity: DiagnosticSeverity.Information,\n range: toRange(ctx.document, stringNode),\n });\n\n return binding;\n },\n set: (binding) => {\n this.contentScore += this.scoreCriteria.modelSet;\n\n this.verboseDetails.push({\n message: `model - set: ${binding} (+${this.scoreCriteria.modelSet}: ${this.contentScore}`,\n severity: DiagnosticSeverity.Information,\n range: toRange(ctx.document, stringNode),\n });\n\n return [];\n },\n delete: () => {},\n },\n evaluate: (str) => {\n this.contentScore += this.scoreCriteria.modelEvaluate;\n\n this.verboseDetails.push({\n message: `model - evaluate: ${str} (+${this.scoreCriteria.modelEvaluate}): ${this.contentScore}`,\n severity: DiagnosticSeverity.Information,\n range: toRange(ctx.document, stringNode),\n });\n\n return str;\n },\n });\n },\n };\n };\n}\n"],"mappings":"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","names":[]}
1
+ {"version":3,"sources":["../../../../../../../../../../../../execroot/_main/bazel-out/k8-fastbuild/bin/language/complexity-check-plugin/src/index.ts","../../../../../../../../../../../../execroot/_main/bazel-out/k8-fastbuild/bin/language/complexity-check-plugin/src/complexity-check.ts"],"sourcesContent":["export * from \"./complexity-check\";\n","import { Diagnostic, DiagnosticSeverity } from \"vscode-languageserver-types\";\nimport { resolveDataRefs } from \"@player-ui/player\";\nimport {\n getProperty,\n isPropertyNode,\n AssetASTNode,\n toRange,\n} from \"@player-tools/json-language-service\";\nimport type {\n ASTNode,\n ASTVisitor,\n PlayerLanguageService,\n PlayerLanguageServicePlugin,\n ViewASTNode,\n DocumentContext,\n} from \"@player-tools/json-language-service\";\n\nconst BASE_WEIGHTS = {\n expInActionState: 1,\n assetNode: 1,\n viewNode: 1,\n template: 1,\n modelGet: 4,\n modelSet: 4,\n modelEvaluate: 4,\n};\n\nexport interface ComplexityCheckConfig {\n /** Cutoff for content to be acceptable */\n maxAcceptableComplexity: number;\n /**\n * If set, any score above this number but below `maxAcceptableComplexity` will be logged as a warning\n */\n maxWarningLevel?: number;\n /** If set, maps additional complexity based on asset or view type */\n typeWeights?: Record<string, number>;\n /** If set, assign override values for the keys specified from baseWeights */\n baseWeightOverrides?: Partial<Record<keyof typeof BASE_WEIGHTS, number>>;\n}\n\n/**\n * Estimates complexity of content\n */\nexport class ComplexityCheck implements PlayerLanguageServicePlugin {\n name = \"complexity-check\";\n\n private config: ComplexityCheckConfig;\n private typeCount: Record<string, number>;\n private contentScore: number;\n private verboseDetails: Diagnostic[];\n private scoreCriteria: Record<string, number>;\n\n constructor(config: ComplexityCheckConfig) {\n this.config = config;\n this.typeCount = {};\n this.contentScore = 0;\n this.verboseDetails = [];\n this.scoreCriteria = { ...BASE_WEIGHTS, ...config.baseWeightOverrides };\n }\n\n apply(service: PlayerLanguageService): void {\n service.hooks.validate.tap(this.name, async (ctx, validation) => {\n validation.useASTVisitor(this.createContentChecker(ctx));\n });\n\n service.hooks.onDocumentUpdate.tap(this.name, () => {\n this.typeCount = {};\n this.contentScore = 0;\n this.verboseDetails = [];\n });\n\n service.hooks.onValidateEnd.tap(this.name, (diagnostics) => {\n const diagnosticRange = {\n start: { line: 0, character: 0 },\n end: { line: 0, character: 0 },\n };\n\n const message = `Content complexity is ${this.contentScore}`;\n\n let diagnostic: Diagnostic = {\n message: `${message}`,\n severity: DiagnosticSeverity.Hint,\n range: diagnosticRange,\n };\n\n if (this.contentScore < this.config.maxAcceptableComplexity) {\n if (\n this.config.maxWarningLevel &&\n this.contentScore > this.config.maxWarningLevel\n ) {\n diagnostic = {\n message: `${message}, Warning: ${this.config.maxWarningLevel}`,\n severity: DiagnosticSeverity.Warning,\n range: diagnosticRange,\n };\n }\n } else {\n diagnostic = {\n message: `${message}, Maximum: ${this.config.maxAcceptableComplexity}`,\n severity: DiagnosticSeverity.Error,\n range: diagnosticRange,\n };\n }\n\n return [diagnostic, ...diagnostics, ...this.verboseDetails];\n });\n }\n\n /** Create a validation visitor for dealing with transition states */\n createContentChecker = (ctx: DocumentContext): ASTVisitor => {\n return {\n FlowStateNode: (flowState) => {\n // Add complexity per expression in a state\n if (flowState.stateType) {\n if (flowState.stateType.valueNode?.value === \"ACTION\") {\n const numExp = getProperty(flowState, \"exp\");\n if (numExp?.valueNode?.type === \"array\") {\n this.contentScore +=\n numExp.valueNode.children.length *\n this.scoreCriteria.expInActionState;\n\n this.verboseDetails.push({\n message: `state exp (+${this.scoreCriteria.expInActionState} x ${numExp.valueNode.children.length}): ${this.contentScore}`,\n severity: DiagnosticSeverity.Hint,\n range: toRange(ctx.document, flowState),\n });\n } else {\n this.contentScore += this.scoreCriteria.expInActionState;\n\n this.verboseDetails.push({\n message: `state exp (+${this.scoreCriteria.expInActionState}): ${this.contentScore}`,\n severity: DiagnosticSeverity.Hint,\n range: toRange(ctx.document, flowState),\n });\n }\n }\n }\n },\n AssetNode: (assetNode: AssetASTNode) => {\n // Recursively check parent nodes for templates\n const checkParentTemplate = (node: ASTNode) => {\n if (node.parent) {\n if (\n isPropertyNode(node.parent) &&\n node.parent.keyNode.value === \"template\"\n ) {\n // Increase the template count each time it finds a nested template\n\n this.contentScore += this.scoreCriteria.template;\n\n this.verboseDetails.push({\n message: `found a template parent (+${this.scoreCriteria.template}): ${this.contentScore}`,\n severity: DiagnosticSeverity.Hint,\n range: toRange(ctx.document, assetNode),\n });\n\n return checkParentTemplate(node.parent);\n }\n return checkParentTemplate(node.parent);\n }\n return node;\n };\n\n checkParentTemplate(assetNode);\n this.contentScore += this.scoreCriteria.assetNode;\n\n const assetType = assetNode.assetType?.valueNode?.value;\n\n // Map the typeWeights score based on the asset type\n const typeWeights = assetType\n ? this.config.typeWeights?.[assetType]\n : undefined;\n\n // Only run if typeWeights is set in the config\n if (this.config.typeWeights) {\n if (typeWeights) {\n this.contentScore += typeWeights;\n if (assetType) {\n // If an assetType is found, add 1 point to typeCount for each occurrence\n if (this.typeCount[assetType] !== undefined) {\n this.typeCount[assetType] += 1;\n } else {\n this.typeCount[assetType] = 1;\n }\n }\n this.verboseDetails.push({\n message: `assetNode (${this.scoreCriteria.assetNode} +${typeWeights} for ${assetType}): ${this.contentScore}`,\n severity: DiagnosticSeverity.Hint,\n range: toRange(ctx.document, assetNode),\n });\n } else {\n this.verboseDetails.push({\n message: `assetNode (+${this.scoreCriteria.assetNode} - ${assetType} complexity type not found): ${this.contentScore}`,\n severity: DiagnosticSeverity.Hint,\n range: toRange(ctx.document, assetNode),\n });\n }\n } else\n this.verboseDetails.push({\n message: `assetNode (+${this.scoreCriteria.assetNode}): ${this.contentScore}`,\n severity: DiagnosticSeverity.Hint,\n range: toRange(ctx.document, assetNode),\n });\n },\n ViewNode: (viewNode: ViewASTNode) => {\n this.contentScore += this.scoreCriteria.viewNode;\n\n const viewType = viewNode.viewType?.valueNode?.value;\n\n // Map the typeWeights score based on the view type\n const viewComplexity = viewType\n ? this.config.typeWeights?.[viewType]\n : undefined;\n\n // Only run if typeWeights is set in the config\n if (this.config.typeWeights) {\n if (viewComplexity) {\n this.contentScore += viewComplexity;\n\n if (viewType) {\n // If a viewType is found, add 1 point to typeCount for each occurrence\n if (this.typeCount[viewType] !== undefined) {\n this.typeCount[viewType] += 1;\n } else {\n this.typeCount[viewType] = 1;\n }\n }\n this.verboseDetails.push({\n message: `viewNode (${this.scoreCriteria.viewNode} +${viewComplexity} for ${viewType}): ${this.contentScore}`,\n severity: DiagnosticSeverity.Hint,\n range: toRange(ctx.document, viewNode),\n });\n } else {\n this.verboseDetails.push({\n message: `viewNode (+${this.scoreCriteria.viewNode} - ${viewType} complexity type not found): ${this.contentScore}`,\n severity: DiagnosticSeverity.Hint,\n range: toRange(ctx.document, viewNode),\n });\n }\n } else\n this.verboseDetails.push({\n message: `viewNode (+${this.scoreCriteria.viewNode}): ${this.contentScore}`,\n severity: DiagnosticSeverity.Hint,\n range: toRange(ctx.document, viewNode),\n });\n },\n StringNode: (stringNode) => {\n const stringContent = stringNode.value;\n resolveDataRefs(stringContent, {\n model: {\n get: (binding) => {\n this.contentScore += this.scoreCriteria.modelGet;\n\n this.verboseDetails.push({\n message: `model - get: ${binding} (+${this.scoreCriteria.modelGet}): ${this.contentScore}`,\n severity: DiagnosticSeverity.Hint,\n range: toRange(ctx.document, stringNode),\n });\n\n return binding;\n },\n set: (binding) => {\n this.contentScore += this.scoreCriteria.modelSet;\n\n this.verboseDetails.push({\n message: `model - set: ${binding} (+${this.scoreCriteria.modelSet}: ${this.contentScore}`,\n severity: DiagnosticSeverity.Hint,\n range: toRange(ctx.document, stringNode),\n });\n\n return [];\n },\n delete: () => {},\n },\n evaluate: (str) => {\n this.contentScore += this.scoreCriteria.modelEvaluate;\n\n this.verboseDetails.push({\n message: `model - evaluate: ${str} (+${this.scoreCriteria.modelEvaluate}): ${this.contentScore}`,\n severity: DiagnosticSeverity.Hint,\n range: toRange(ctx.document, stringNode),\n });\n\n return str;\n },\n });\n },\n };\n };\n}\n"],"mappings":"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","names":[]}
@@ -46,7 +46,7 @@ var ComplexityCheck = class {
46
46
  const message = `Content complexity is ${this.contentScore}`;
47
47
  let diagnostic = {
48
48
  message: `${message}`,
49
- severity: DiagnosticSeverity.Information,
49
+ severity: DiagnosticSeverity.Hint,
50
50
  range: diagnosticRange
51
51
  };
52
52
  if (this.contentScore < this.config.maxAcceptableComplexity) {
@@ -78,14 +78,14 @@ var ComplexityCheck = class {
78
78
  this.contentScore += numExp.valueNode.children.length * this.scoreCriteria.expInActionState;
79
79
  this.verboseDetails.push({
80
80
  message: `state exp (+${this.scoreCriteria.expInActionState} x ${numExp.valueNode.children.length}): ${this.contentScore}`,
81
- severity: DiagnosticSeverity.Information,
81
+ severity: DiagnosticSeverity.Hint,
82
82
  range: toRange(ctx.document, flowState)
83
83
  });
84
84
  } else {
85
85
  this.contentScore += this.scoreCriteria.expInActionState;
86
86
  this.verboseDetails.push({
87
87
  message: `state exp (+${this.scoreCriteria.expInActionState}): ${this.contentScore}`,
88
- severity: DiagnosticSeverity.Information,
88
+ severity: DiagnosticSeverity.Hint,
89
89
  range: toRange(ctx.document, flowState)
90
90
  });
91
91
  }
@@ -99,7 +99,7 @@ var ComplexityCheck = class {
99
99
  this.contentScore += this.scoreCriteria.template;
100
100
  this.verboseDetails.push({
101
101
  message: `found a template parent (+${this.scoreCriteria.template}): ${this.contentScore}`,
102
- severity: DiagnosticSeverity.Information,
102
+ severity: DiagnosticSeverity.Hint,
103
103
  range: toRange(ctx.document, assetNode)
104
104
  });
105
105
  return checkParentTemplate(node.parent);
@@ -124,20 +124,20 @@ var ComplexityCheck = class {
124
124
  }
125
125
  this.verboseDetails.push({
126
126
  message: `assetNode (${this.scoreCriteria.assetNode} +${typeWeights} for ${assetType}): ${this.contentScore}`,
127
- severity: DiagnosticSeverity.Information,
127
+ severity: DiagnosticSeverity.Hint,
128
128
  range: toRange(ctx.document, assetNode)
129
129
  });
130
130
  } else {
131
131
  this.verboseDetails.push({
132
132
  message: `assetNode (+${this.scoreCriteria.assetNode} - ${assetType} complexity type not found): ${this.contentScore}`,
133
- severity: DiagnosticSeverity.Information,
133
+ severity: DiagnosticSeverity.Hint,
134
134
  range: toRange(ctx.document, assetNode)
135
135
  });
136
136
  }
137
137
  } else
138
138
  this.verboseDetails.push({
139
139
  message: `assetNode (+${this.scoreCriteria.assetNode}): ${this.contentScore}`,
140
- severity: DiagnosticSeverity.Information,
140
+ severity: DiagnosticSeverity.Hint,
141
141
  range: toRange(ctx.document, assetNode)
142
142
  });
143
143
  },
@@ -157,20 +157,20 @@ var ComplexityCheck = class {
157
157
  }
158
158
  this.verboseDetails.push({
159
159
  message: `viewNode (${this.scoreCriteria.viewNode} +${viewComplexity} for ${viewType}): ${this.contentScore}`,
160
- severity: DiagnosticSeverity.Information,
160
+ severity: DiagnosticSeverity.Hint,
161
161
  range: toRange(ctx.document, viewNode)
162
162
  });
163
163
  } else {
164
164
  this.verboseDetails.push({
165
165
  message: `viewNode (+${this.scoreCriteria.viewNode} - ${viewType} complexity type not found): ${this.contentScore}`,
166
- severity: DiagnosticSeverity.Information,
166
+ severity: DiagnosticSeverity.Hint,
167
167
  range: toRange(ctx.document, viewNode)
168
168
  });
169
169
  }
170
170
  } else
171
171
  this.verboseDetails.push({
172
172
  message: `viewNode (+${this.scoreCriteria.viewNode}): ${this.contentScore}`,
173
- severity: DiagnosticSeverity.Information,
173
+ severity: DiagnosticSeverity.Hint,
174
174
  range: toRange(ctx.document, viewNode)
175
175
  });
176
176
  },
@@ -182,7 +182,7 @@ var ComplexityCheck = class {
182
182
  this.contentScore += this.scoreCriteria.modelGet;
183
183
  this.verboseDetails.push({
184
184
  message: `model - get: ${binding} (+${this.scoreCriteria.modelGet}): ${this.contentScore}`,
185
- severity: DiagnosticSeverity.Information,
185
+ severity: DiagnosticSeverity.Hint,
186
186
  range: toRange(ctx.document, stringNode)
187
187
  });
188
188
  return binding;
@@ -191,7 +191,7 @@ var ComplexityCheck = class {
191
191
  this.contentScore += this.scoreCriteria.modelSet;
192
192
  this.verboseDetails.push({
193
193
  message: `model - set: ${binding} (+${this.scoreCriteria.modelSet}: ${this.contentScore}`,
194
- severity: DiagnosticSeverity.Information,
194
+ severity: DiagnosticSeverity.Hint,
195
195
  range: toRange(ctx.document, stringNode)
196
196
  });
197
197
  return [];
@@ -203,7 +203,7 @@ var ComplexityCheck = class {
203
203
  this.contentScore += this.scoreCriteria.modelEvaluate;
204
204
  this.verboseDetails.push({
205
205
  message: `model - evaluate: ${str} (+${this.scoreCriteria.modelEvaluate}): ${this.contentScore}`,
206
- severity: DiagnosticSeverity.Information,
206
+ severity: DiagnosticSeverity.Hint,
207
207
  range: toRange(ctx.document, stringNode)
208
208
  });
209
209
  return str;
package/dist/index.mjs CHANGED
@@ -46,7 +46,7 @@ var ComplexityCheck = class {
46
46
  const message = `Content complexity is ${this.contentScore}`;
47
47
  let diagnostic = {
48
48
  message: `${message}`,
49
- severity: DiagnosticSeverity.Information,
49
+ severity: DiagnosticSeverity.Hint,
50
50
  range: diagnosticRange
51
51
  };
52
52
  if (this.contentScore < this.config.maxAcceptableComplexity) {
@@ -78,14 +78,14 @@ var ComplexityCheck = class {
78
78
  this.contentScore += numExp.valueNode.children.length * this.scoreCriteria.expInActionState;
79
79
  this.verboseDetails.push({
80
80
  message: `state exp (+${this.scoreCriteria.expInActionState} x ${numExp.valueNode.children.length}): ${this.contentScore}`,
81
- severity: DiagnosticSeverity.Information,
81
+ severity: DiagnosticSeverity.Hint,
82
82
  range: toRange(ctx.document, flowState)
83
83
  });
84
84
  } else {
85
85
  this.contentScore += this.scoreCriteria.expInActionState;
86
86
  this.verboseDetails.push({
87
87
  message: `state exp (+${this.scoreCriteria.expInActionState}): ${this.contentScore}`,
88
- severity: DiagnosticSeverity.Information,
88
+ severity: DiagnosticSeverity.Hint,
89
89
  range: toRange(ctx.document, flowState)
90
90
  });
91
91
  }
@@ -99,7 +99,7 @@ var ComplexityCheck = class {
99
99
  this.contentScore += this.scoreCriteria.template;
100
100
  this.verboseDetails.push({
101
101
  message: `found a template parent (+${this.scoreCriteria.template}): ${this.contentScore}`,
102
- severity: DiagnosticSeverity.Information,
102
+ severity: DiagnosticSeverity.Hint,
103
103
  range: toRange(ctx.document, assetNode)
104
104
  });
105
105
  return checkParentTemplate(node.parent);
@@ -124,20 +124,20 @@ var ComplexityCheck = class {
124
124
  }
125
125
  this.verboseDetails.push({
126
126
  message: `assetNode (${this.scoreCriteria.assetNode} +${typeWeights} for ${assetType}): ${this.contentScore}`,
127
- severity: DiagnosticSeverity.Information,
127
+ severity: DiagnosticSeverity.Hint,
128
128
  range: toRange(ctx.document, assetNode)
129
129
  });
130
130
  } else {
131
131
  this.verboseDetails.push({
132
132
  message: `assetNode (+${this.scoreCriteria.assetNode} - ${assetType} complexity type not found): ${this.contentScore}`,
133
- severity: DiagnosticSeverity.Information,
133
+ severity: DiagnosticSeverity.Hint,
134
134
  range: toRange(ctx.document, assetNode)
135
135
  });
136
136
  }
137
137
  } else
138
138
  this.verboseDetails.push({
139
139
  message: `assetNode (+${this.scoreCriteria.assetNode}): ${this.contentScore}`,
140
- severity: DiagnosticSeverity.Information,
140
+ severity: DiagnosticSeverity.Hint,
141
141
  range: toRange(ctx.document, assetNode)
142
142
  });
143
143
  },
@@ -157,20 +157,20 @@ var ComplexityCheck = class {
157
157
  }
158
158
  this.verboseDetails.push({
159
159
  message: `viewNode (${this.scoreCriteria.viewNode} +${viewComplexity} for ${viewType}): ${this.contentScore}`,
160
- severity: DiagnosticSeverity.Information,
160
+ severity: DiagnosticSeverity.Hint,
161
161
  range: toRange(ctx.document, viewNode)
162
162
  });
163
163
  } else {
164
164
  this.verboseDetails.push({
165
165
  message: `viewNode (+${this.scoreCriteria.viewNode} - ${viewType} complexity type not found): ${this.contentScore}`,
166
- severity: DiagnosticSeverity.Information,
166
+ severity: DiagnosticSeverity.Hint,
167
167
  range: toRange(ctx.document, viewNode)
168
168
  });
169
169
  }
170
170
  } else
171
171
  this.verboseDetails.push({
172
172
  message: `viewNode (+${this.scoreCriteria.viewNode}): ${this.contentScore}`,
173
- severity: DiagnosticSeverity.Information,
173
+ severity: DiagnosticSeverity.Hint,
174
174
  range: toRange(ctx.document, viewNode)
175
175
  });
176
176
  },
@@ -182,7 +182,7 @@ var ComplexityCheck = class {
182
182
  this.contentScore += this.scoreCriteria.modelGet;
183
183
  this.verboseDetails.push({
184
184
  message: `model - get: ${binding} (+${this.scoreCriteria.modelGet}): ${this.contentScore}`,
185
- severity: DiagnosticSeverity.Information,
185
+ severity: DiagnosticSeverity.Hint,
186
186
  range: toRange(ctx.document, stringNode)
187
187
  });
188
188
  return binding;
@@ -191,7 +191,7 @@ var ComplexityCheck = class {
191
191
  this.contentScore += this.scoreCriteria.modelSet;
192
192
  this.verboseDetails.push({
193
193
  message: `model - set: ${binding} (+${this.scoreCriteria.modelSet}: ${this.contentScore}`,
194
- severity: DiagnosticSeverity.Information,
194
+ severity: DiagnosticSeverity.Hint,
195
195
  range: toRange(ctx.document, stringNode)
196
196
  });
197
197
  return [];
@@ -203,7 +203,7 @@ var ComplexityCheck = class {
203
203
  this.contentScore += this.scoreCriteria.modelEvaluate;
204
204
  this.verboseDetails.push({
205
205
  message: `model - evaluate: ${str} (+${this.scoreCriteria.modelEvaluate}): ${this.contentScore}`,
206
- severity: DiagnosticSeverity.Information,
206
+ severity: DiagnosticSeverity.Hint,
207
207
  range: toRange(ctx.document, stringNode)
208
208
  });
209
209
  return str;
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../../../../../../../../../execroot/_main/bazel-out/k8-fastbuild/bin/language/complexity-check-plugin/src/complexity-check.ts"],"sourcesContent":["import { Diagnostic, DiagnosticSeverity } from \"vscode-languageserver-types\";\nimport { resolveDataRefs } from \"@player-ui/player\";\nimport {\n getProperty,\n isPropertyNode,\n AssetASTNode,\n toRange,\n} from \"@player-tools/json-language-service\";\nimport type {\n ASTNode,\n ASTVisitor,\n PlayerLanguageService,\n PlayerLanguageServicePlugin,\n ViewASTNode,\n DocumentContext,\n} from \"@player-tools/json-language-service\";\n\nconst BASE_WEIGHTS = {\n expInActionState: 1,\n assetNode: 1,\n viewNode: 1,\n template: 1,\n modelGet: 4,\n modelSet: 4,\n modelEvaluate: 4,\n};\n\nexport interface ComplexityCheckConfig {\n /** Cutoff for content to be acceptable */\n maxAcceptableComplexity: number;\n /**\n * If set, any score above this number but below `maxAcceptableComplexity` will be logged as a warning\n */\n maxWarningLevel?: number;\n /** If set, maps additional complexity based on asset or view type */\n typeWeights?: Record<string, number>;\n /** If set, assign override values for the keys specified from baseWeights */\n baseWeightOverrides?: Partial<Record<keyof typeof BASE_WEIGHTS, number>>;\n}\n\n/**\n * Estimates complexity of content\n */\nexport class ComplexityCheck implements PlayerLanguageServicePlugin {\n name = \"complexity-check\";\n\n private config: ComplexityCheckConfig;\n private typeCount: Record<string, number>;\n private contentScore: number;\n private verboseDetails: Diagnostic[];\n private scoreCriteria: Record<string, number>;\n\n constructor(config: ComplexityCheckConfig) {\n this.config = config;\n this.typeCount = {};\n this.contentScore = 0;\n this.verboseDetails = [];\n this.scoreCriteria = { ...BASE_WEIGHTS, ...config.baseWeightOverrides };\n }\n\n apply(service: PlayerLanguageService): void {\n service.hooks.validate.tap(this.name, async (ctx, validation) => {\n validation.useASTVisitor(this.createContentChecker(ctx));\n });\n\n service.hooks.onDocumentUpdate.tap(this.name, () => {\n this.typeCount = {};\n this.contentScore = 0;\n this.verboseDetails = [];\n });\n\n service.hooks.onValidateEnd.tap(this.name, (diagnostics) => {\n const diagnosticRange = {\n start: { line: 0, character: 0 },\n end: { line: 0, character: 0 },\n };\n\n const message = `Content complexity is ${this.contentScore}`;\n\n let diagnostic: Diagnostic = {\n message: `${message}`,\n severity: DiagnosticSeverity.Information,\n range: diagnosticRange,\n };\n\n if (this.contentScore < this.config.maxAcceptableComplexity) {\n if (\n this.config.maxWarningLevel &&\n this.contentScore > this.config.maxWarningLevel\n ) {\n diagnostic = {\n message: `${message}, Warning: ${this.config.maxWarningLevel}`,\n severity: DiagnosticSeverity.Warning,\n range: diagnosticRange,\n };\n }\n } else {\n diagnostic = {\n message: `${message}, Maximum: ${this.config.maxAcceptableComplexity}`,\n severity: DiagnosticSeverity.Error,\n range: diagnosticRange,\n };\n }\n\n return [diagnostic, ...diagnostics, ...this.verboseDetails];\n });\n }\n\n /** Create a validation visitor for dealing with transition states */\n createContentChecker = (ctx: DocumentContext): ASTVisitor => {\n return {\n FlowStateNode: (flowState) => {\n // Add complexity per expression in a state\n if (flowState.stateType) {\n if (flowState.stateType.valueNode?.value === \"ACTION\") {\n const numExp = getProperty(flowState, \"exp\");\n if (numExp?.valueNode?.type === \"array\") {\n this.contentScore +=\n numExp.valueNode.children.length *\n this.scoreCriteria.expInActionState;\n\n this.verboseDetails.push({\n message: `state exp (+${this.scoreCriteria.expInActionState} x ${numExp.valueNode.children.length}): ${this.contentScore}`,\n severity: DiagnosticSeverity.Information,\n range: toRange(ctx.document, flowState),\n });\n } else {\n this.contentScore += this.scoreCriteria.expInActionState;\n\n this.verboseDetails.push({\n message: `state exp (+${this.scoreCriteria.expInActionState}): ${this.contentScore}`,\n severity: DiagnosticSeverity.Information,\n range: toRange(ctx.document, flowState),\n });\n }\n }\n }\n },\n AssetNode: (assetNode: AssetASTNode) => {\n // Recursively check parent nodes for templates\n const checkParentTemplate = (node: ASTNode) => {\n if (node.parent) {\n if (\n isPropertyNode(node.parent) &&\n node.parent.keyNode.value === \"template\"\n ) {\n // Increase the template count each time it finds a nested template\n\n this.contentScore += this.scoreCriteria.template;\n\n this.verboseDetails.push({\n message: `found a template parent (+${this.scoreCriteria.template}): ${this.contentScore}`,\n severity: DiagnosticSeverity.Information,\n range: toRange(ctx.document, assetNode),\n });\n\n return checkParentTemplate(node.parent);\n }\n return checkParentTemplate(node.parent);\n }\n return node;\n };\n\n checkParentTemplate(assetNode);\n this.contentScore += this.scoreCriteria.assetNode;\n\n const assetType = assetNode.assetType?.valueNode?.value;\n\n // Map the typeWeights score based on the asset type\n const typeWeights = assetType\n ? this.config.typeWeights?.[assetType]\n : undefined;\n\n // Only run if typeWeights is set in the config\n if (this.config.typeWeights) {\n if (typeWeights) {\n this.contentScore += typeWeights;\n if (assetType) {\n // If an assetType is found, add 1 point to typeCount for each occurrence\n if (this.typeCount[assetType] !== undefined) {\n this.typeCount[assetType] += 1;\n } else {\n this.typeCount[assetType] = 1;\n }\n }\n this.verboseDetails.push({\n message: `assetNode (${this.scoreCriteria.assetNode} +${typeWeights} for ${assetType}): ${this.contentScore}`,\n severity: DiagnosticSeverity.Information,\n range: toRange(ctx.document, assetNode),\n });\n } else {\n this.verboseDetails.push({\n message: `assetNode (+${this.scoreCriteria.assetNode} - ${assetType} complexity type not found): ${this.contentScore}`,\n severity: DiagnosticSeverity.Information,\n range: toRange(ctx.document, assetNode),\n });\n }\n } else\n this.verboseDetails.push({\n message: `assetNode (+${this.scoreCriteria.assetNode}): ${this.contentScore}`,\n severity: DiagnosticSeverity.Information,\n range: toRange(ctx.document, assetNode),\n });\n },\n ViewNode: (viewNode: ViewASTNode) => {\n this.contentScore += this.scoreCriteria.viewNode;\n\n const viewType = viewNode.viewType?.valueNode?.value;\n\n // Map the typeWeights score based on the view type\n const viewComplexity = viewType\n ? this.config.typeWeights?.[viewType]\n : undefined;\n\n // Only run if typeWeights is set in the config\n if (this.config.typeWeights) {\n if (viewComplexity) {\n this.contentScore += viewComplexity;\n\n if (viewType) {\n // If a viewType is found, add 1 point to typeCount for each occurrence\n if (this.typeCount[viewType] !== undefined) {\n this.typeCount[viewType] += 1;\n } else {\n this.typeCount[viewType] = 1;\n }\n }\n this.verboseDetails.push({\n message: `viewNode (${this.scoreCriteria.viewNode} +${viewComplexity} for ${viewType}): ${this.contentScore}`,\n severity: DiagnosticSeverity.Information,\n range: toRange(ctx.document, viewNode),\n });\n } else {\n this.verboseDetails.push({\n message: `viewNode (+${this.scoreCriteria.viewNode} - ${viewType} complexity type not found): ${this.contentScore}`,\n severity: DiagnosticSeverity.Information,\n range: toRange(ctx.document, viewNode),\n });\n }\n } else\n this.verboseDetails.push({\n message: `viewNode (+${this.scoreCriteria.viewNode}): ${this.contentScore}`,\n severity: DiagnosticSeverity.Information,\n range: toRange(ctx.document, viewNode),\n });\n },\n StringNode: (stringNode) => {\n const stringContent = stringNode.value;\n resolveDataRefs(stringContent, {\n model: {\n get: (binding) => {\n this.contentScore += this.scoreCriteria.modelGet;\n\n this.verboseDetails.push({\n message: `model - get: ${binding} (+${this.scoreCriteria.modelGet}): ${this.contentScore}`,\n severity: DiagnosticSeverity.Information,\n range: toRange(ctx.document, stringNode),\n });\n\n return binding;\n },\n set: (binding) => {\n this.contentScore += this.scoreCriteria.modelSet;\n\n this.verboseDetails.push({\n message: `model - set: ${binding} (+${this.scoreCriteria.modelSet}: ${this.contentScore}`,\n severity: DiagnosticSeverity.Information,\n range: toRange(ctx.document, stringNode),\n });\n\n return [];\n },\n delete: () => {},\n },\n evaluate: (str) => {\n this.contentScore += this.scoreCriteria.modelEvaluate;\n\n this.verboseDetails.push({\n message: `model - evaluate: ${str} (+${this.scoreCriteria.modelEvaluate}): ${this.contentScore}`,\n severity: DiagnosticSeverity.Information,\n range: toRange(ctx.document, stringNode),\n });\n\n return str;\n },\n });\n },\n };\n };\n}\n"],"mappings":"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","names":[]}
1
+ {"version":3,"sources":["../../../../../../../../../../../execroot/_main/bazel-out/k8-fastbuild/bin/language/complexity-check-plugin/src/complexity-check.ts"],"sourcesContent":["import { Diagnostic, DiagnosticSeverity } from \"vscode-languageserver-types\";\nimport { resolveDataRefs } from \"@player-ui/player\";\nimport {\n getProperty,\n isPropertyNode,\n AssetASTNode,\n toRange,\n} from \"@player-tools/json-language-service\";\nimport type {\n ASTNode,\n ASTVisitor,\n PlayerLanguageService,\n PlayerLanguageServicePlugin,\n ViewASTNode,\n DocumentContext,\n} from \"@player-tools/json-language-service\";\n\nconst BASE_WEIGHTS = {\n expInActionState: 1,\n assetNode: 1,\n viewNode: 1,\n template: 1,\n modelGet: 4,\n modelSet: 4,\n modelEvaluate: 4,\n};\n\nexport interface ComplexityCheckConfig {\n /** Cutoff for content to be acceptable */\n maxAcceptableComplexity: number;\n /**\n * If set, any score above this number but below `maxAcceptableComplexity` will be logged as a warning\n */\n maxWarningLevel?: number;\n /** If set, maps additional complexity based on asset or view type */\n typeWeights?: Record<string, number>;\n /** If set, assign override values for the keys specified from baseWeights */\n baseWeightOverrides?: Partial<Record<keyof typeof BASE_WEIGHTS, number>>;\n}\n\n/**\n * Estimates complexity of content\n */\nexport class ComplexityCheck implements PlayerLanguageServicePlugin {\n name = \"complexity-check\";\n\n private config: ComplexityCheckConfig;\n private typeCount: Record<string, number>;\n private contentScore: number;\n private verboseDetails: Diagnostic[];\n private scoreCriteria: Record<string, number>;\n\n constructor(config: ComplexityCheckConfig) {\n this.config = config;\n this.typeCount = {};\n this.contentScore = 0;\n this.verboseDetails = [];\n this.scoreCriteria = { ...BASE_WEIGHTS, ...config.baseWeightOverrides };\n }\n\n apply(service: PlayerLanguageService): void {\n service.hooks.validate.tap(this.name, async (ctx, validation) => {\n validation.useASTVisitor(this.createContentChecker(ctx));\n });\n\n service.hooks.onDocumentUpdate.tap(this.name, () => {\n this.typeCount = {};\n this.contentScore = 0;\n this.verboseDetails = [];\n });\n\n service.hooks.onValidateEnd.tap(this.name, (diagnostics) => {\n const diagnosticRange = {\n start: { line: 0, character: 0 },\n end: { line: 0, character: 0 },\n };\n\n const message = `Content complexity is ${this.contentScore}`;\n\n let diagnostic: Diagnostic = {\n message: `${message}`,\n severity: DiagnosticSeverity.Hint,\n range: diagnosticRange,\n };\n\n if (this.contentScore < this.config.maxAcceptableComplexity) {\n if (\n this.config.maxWarningLevel &&\n this.contentScore > this.config.maxWarningLevel\n ) {\n diagnostic = {\n message: `${message}, Warning: ${this.config.maxWarningLevel}`,\n severity: DiagnosticSeverity.Warning,\n range: diagnosticRange,\n };\n }\n } else {\n diagnostic = {\n message: `${message}, Maximum: ${this.config.maxAcceptableComplexity}`,\n severity: DiagnosticSeverity.Error,\n range: diagnosticRange,\n };\n }\n\n return [diagnostic, ...diagnostics, ...this.verboseDetails];\n });\n }\n\n /** Create a validation visitor for dealing with transition states */\n createContentChecker = (ctx: DocumentContext): ASTVisitor => {\n return {\n FlowStateNode: (flowState) => {\n // Add complexity per expression in a state\n if (flowState.stateType) {\n if (flowState.stateType.valueNode?.value === \"ACTION\") {\n const numExp = getProperty(flowState, \"exp\");\n if (numExp?.valueNode?.type === \"array\") {\n this.contentScore +=\n numExp.valueNode.children.length *\n this.scoreCriteria.expInActionState;\n\n this.verboseDetails.push({\n message: `state exp (+${this.scoreCriteria.expInActionState} x ${numExp.valueNode.children.length}): ${this.contentScore}`,\n severity: DiagnosticSeverity.Hint,\n range: toRange(ctx.document, flowState),\n });\n } else {\n this.contentScore += this.scoreCriteria.expInActionState;\n\n this.verboseDetails.push({\n message: `state exp (+${this.scoreCriteria.expInActionState}): ${this.contentScore}`,\n severity: DiagnosticSeverity.Hint,\n range: toRange(ctx.document, flowState),\n });\n }\n }\n }\n },\n AssetNode: (assetNode: AssetASTNode) => {\n // Recursively check parent nodes for templates\n const checkParentTemplate = (node: ASTNode) => {\n if (node.parent) {\n if (\n isPropertyNode(node.parent) &&\n node.parent.keyNode.value === \"template\"\n ) {\n // Increase the template count each time it finds a nested template\n\n this.contentScore += this.scoreCriteria.template;\n\n this.verboseDetails.push({\n message: `found a template parent (+${this.scoreCriteria.template}): ${this.contentScore}`,\n severity: DiagnosticSeverity.Hint,\n range: toRange(ctx.document, assetNode),\n });\n\n return checkParentTemplate(node.parent);\n }\n return checkParentTemplate(node.parent);\n }\n return node;\n };\n\n checkParentTemplate(assetNode);\n this.contentScore += this.scoreCriteria.assetNode;\n\n const assetType = assetNode.assetType?.valueNode?.value;\n\n // Map the typeWeights score based on the asset type\n const typeWeights = assetType\n ? this.config.typeWeights?.[assetType]\n : undefined;\n\n // Only run if typeWeights is set in the config\n if (this.config.typeWeights) {\n if (typeWeights) {\n this.contentScore += typeWeights;\n if (assetType) {\n // If an assetType is found, add 1 point to typeCount for each occurrence\n if (this.typeCount[assetType] !== undefined) {\n this.typeCount[assetType] += 1;\n } else {\n this.typeCount[assetType] = 1;\n }\n }\n this.verboseDetails.push({\n message: `assetNode (${this.scoreCriteria.assetNode} +${typeWeights} for ${assetType}): ${this.contentScore}`,\n severity: DiagnosticSeverity.Hint,\n range: toRange(ctx.document, assetNode),\n });\n } else {\n this.verboseDetails.push({\n message: `assetNode (+${this.scoreCriteria.assetNode} - ${assetType} complexity type not found): ${this.contentScore}`,\n severity: DiagnosticSeverity.Hint,\n range: toRange(ctx.document, assetNode),\n });\n }\n } else\n this.verboseDetails.push({\n message: `assetNode (+${this.scoreCriteria.assetNode}): ${this.contentScore}`,\n severity: DiagnosticSeverity.Hint,\n range: toRange(ctx.document, assetNode),\n });\n },\n ViewNode: (viewNode: ViewASTNode) => {\n this.contentScore += this.scoreCriteria.viewNode;\n\n const viewType = viewNode.viewType?.valueNode?.value;\n\n // Map the typeWeights score based on the view type\n const viewComplexity = viewType\n ? this.config.typeWeights?.[viewType]\n : undefined;\n\n // Only run if typeWeights is set in the config\n if (this.config.typeWeights) {\n if (viewComplexity) {\n this.contentScore += viewComplexity;\n\n if (viewType) {\n // If a viewType is found, add 1 point to typeCount for each occurrence\n if (this.typeCount[viewType] !== undefined) {\n this.typeCount[viewType] += 1;\n } else {\n this.typeCount[viewType] = 1;\n }\n }\n this.verboseDetails.push({\n message: `viewNode (${this.scoreCriteria.viewNode} +${viewComplexity} for ${viewType}): ${this.contentScore}`,\n severity: DiagnosticSeverity.Hint,\n range: toRange(ctx.document, viewNode),\n });\n } else {\n this.verboseDetails.push({\n message: `viewNode (+${this.scoreCriteria.viewNode} - ${viewType} complexity type not found): ${this.contentScore}`,\n severity: DiagnosticSeverity.Hint,\n range: toRange(ctx.document, viewNode),\n });\n }\n } else\n this.verboseDetails.push({\n message: `viewNode (+${this.scoreCriteria.viewNode}): ${this.contentScore}`,\n severity: DiagnosticSeverity.Hint,\n range: toRange(ctx.document, viewNode),\n });\n },\n StringNode: (stringNode) => {\n const stringContent = stringNode.value;\n resolveDataRefs(stringContent, {\n model: {\n get: (binding) => {\n this.contentScore += this.scoreCriteria.modelGet;\n\n this.verboseDetails.push({\n message: `model - get: ${binding} (+${this.scoreCriteria.modelGet}): ${this.contentScore}`,\n severity: DiagnosticSeverity.Hint,\n range: toRange(ctx.document, stringNode),\n });\n\n return binding;\n },\n set: (binding) => {\n this.contentScore += this.scoreCriteria.modelSet;\n\n this.verboseDetails.push({\n message: `model - set: ${binding} (+${this.scoreCriteria.modelSet}: ${this.contentScore}`,\n severity: DiagnosticSeverity.Hint,\n range: toRange(ctx.document, stringNode),\n });\n\n return [];\n },\n delete: () => {},\n },\n evaluate: (str) => {\n this.contentScore += this.scoreCriteria.modelEvaluate;\n\n this.verboseDetails.push({\n message: `model - evaluate: ${str} (+${this.scoreCriteria.modelEvaluate}): ${this.contentScore}`,\n severity: DiagnosticSeverity.Hint,\n range: toRange(ctx.document, stringNode),\n });\n\n return str;\n },\n });\n },\n };\n };\n}\n"],"mappings":"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","names":[]}
package/package.json CHANGED
@@ -6,10 +6,10 @@
6
6
  "types"
7
7
  ],
8
8
  "name": "@player-tools/complexity-check-plugin",
9
- "version": "0.9.1-next.2",
9
+ "version": "0.10.0-next.0",
10
10
  "main": "dist/cjs/index.cjs",
11
11
  "dependencies": {
12
- "@player-tools/json-language-service": "0.9.1-next.2",
12
+ "@player-tools/json-language-service": "0.10.0-next.0",
13
13
  "@player-ui/player": "0.7.3",
14
14
  "jsonc-parser": "^2.3.1",
15
15
  "typescript-template-language-service-decorator": "^2.3.1",
@@ -79,7 +79,7 @@ export class ComplexityCheck implements PlayerLanguageServicePlugin {
79
79
 
80
80
  let diagnostic: Diagnostic = {
81
81
  message: `${message}`,
82
- severity: DiagnosticSeverity.Information,
82
+ severity: DiagnosticSeverity.Hint,
83
83
  range: diagnosticRange,
84
84
  };
85
85
 
@@ -121,7 +121,7 @@ export class ComplexityCheck implements PlayerLanguageServicePlugin {
121
121
 
122
122
  this.verboseDetails.push({
123
123
  message: `state exp (+${this.scoreCriteria.expInActionState} x ${numExp.valueNode.children.length}): ${this.contentScore}`,
124
- severity: DiagnosticSeverity.Information,
124
+ severity: DiagnosticSeverity.Hint,
125
125
  range: toRange(ctx.document, flowState),
126
126
  });
127
127
  } else {
@@ -129,7 +129,7 @@ export class ComplexityCheck implements PlayerLanguageServicePlugin {
129
129
 
130
130
  this.verboseDetails.push({
131
131
  message: `state exp (+${this.scoreCriteria.expInActionState}): ${this.contentScore}`,
132
- severity: DiagnosticSeverity.Information,
132
+ severity: DiagnosticSeverity.Hint,
133
133
  range: toRange(ctx.document, flowState),
134
134
  });
135
135
  }
@@ -150,7 +150,7 @@ export class ComplexityCheck implements PlayerLanguageServicePlugin {
150
150
 
151
151
  this.verboseDetails.push({
152
152
  message: `found a template parent (+${this.scoreCriteria.template}): ${this.contentScore}`,
153
- severity: DiagnosticSeverity.Information,
153
+ severity: DiagnosticSeverity.Hint,
154
154
  range: toRange(ctx.document, assetNode),
155
155
  });
156
156
 
@@ -185,20 +185,20 @@ export class ComplexityCheck implements PlayerLanguageServicePlugin {
185
185
  }
186
186
  this.verboseDetails.push({
187
187
  message: `assetNode (${this.scoreCriteria.assetNode} +${typeWeights} for ${assetType}): ${this.contentScore}`,
188
- severity: DiagnosticSeverity.Information,
188
+ severity: DiagnosticSeverity.Hint,
189
189
  range: toRange(ctx.document, assetNode),
190
190
  });
191
191
  } else {
192
192
  this.verboseDetails.push({
193
193
  message: `assetNode (+${this.scoreCriteria.assetNode} - ${assetType} complexity type not found): ${this.contentScore}`,
194
- severity: DiagnosticSeverity.Information,
194
+ severity: DiagnosticSeverity.Hint,
195
195
  range: toRange(ctx.document, assetNode),
196
196
  });
197
197
  }
198
198
  } else
199
199
  this.verboseDetails.push({
200
200
  message: `assetNode (+${this.scoreCriteria.assetNode}): ${this.contentScore}`,
201
- severity: DiagnosticSeverity.Information,
201
+ severity: DiagnosticSeverity.Hint,
202
202
  range: toRange(ctx.document, assetNode),
203
203
  });
204
204
  },
@@ -227,20 +227,20 @@ export class ComplexityCheck implements PlayerLanguageServicePlugin {
227
227
  }
228
228
  this.verboseDetails.push({
229
229
  message: `viewNode (${this.scoreCriteria.viewNode} +${viewComplexity} for ${viewType}): ${this.contentScore}`,
230
- severity: DiagnosticSeverity.Information,
230
+ severity: DiagnosticSeverity.Hint,
231
231
  range: toRange(ctx.document, viewNode),
232
232
  });
233
233
  } else {
234
234
  this.verboseDetails.push({
235
235
  message: `viewNode (+${this.scoreCriteria.viewNode} - ${viewType} complexity type not found): ${this.contentScore}`,
236
- severity: DiagnosticSeverity.Information,
236
+ severity: DiagnosticSeverity.Hint,
237
237
  range: toRange(ctx.document, viewNode),
238
238
  });
239
239
  }
240
240
  } else
241
241
  this.verboseDetails.push({
242
242
  message: `viewNode (+${this.scoreCriteria.viewNode}): ${this.contentScore}`,
243
- severity: DiagnosticSeverity.Information,
243
+ severity: DiagnosticSeverity.Hint,
244
244
  range: toRange(ctx.document, viewNode),
245
245
  });
246
246
  },
@@ -253,7 +253,7 @@ export class ComplexityCheck implements PlayerLanguageServicePlugin {
253
253
 
254
254
  this.verboseDetails.push({
255
255
  message: `model - get: ${binding} (+${this.scoreCriteria.modelGet}): ${this.contentScore}`,
256
- severity: DiagnosticSeverity.Information,
256
+ severity: DiagnosticSeverity.Hint,
257
257
  range: toRange(ctx.document, stringNode),
258
258
  });
259
259
 
@@ -264,7 +264,7 @@ export class ComplexityCheck implements PlayerLanguageServicePlugin {
264
264
 
265
265
  this.verboseDetails.push({
266
266
  message: `model - set: ${binding} (+${this.scoreCriteria.modelSet}: ${this.contentScore}`,
267
- severity: DiagnosticSeverity.Information,
267
+ severity: DiagnosticSeverity.Hint,
268
268
  range: toRange(ctx.document, stringNode),
269
269
  });
270
270
 
@@ -277,7 +277,7 @@ export class ComplexityCheck implements PlayerLanguageServicePlugin {
277
277
 
278
278
  this.verboseDetails.push({
279
279
  message: `model - evaluate: ${str} (+${this.scoreCriteria.modelEvaluate}): ${this.contentScore}`,
280
- severity: DiagnosticSeverity.Information,
280
+ severity: DiagnosticSeverity.Hint,
281
281
  range: toRange(ctx.document, stringNode),
282
282
  });
283
283