@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.
- package/dist/cjs/index.cjs +13 -13
- package/dist/cjs/index.cjs.map +1 -1
- package/dist/index.legacy-esm.js +13 -13
- package/dist/index.mjs +13 -13
- package/dist/index.mjs.map +1 -1
- package/package.json +2 -2
- package/src/complexity-check.ts +13 -13
package/dist/cjs/index.cjs
CHANGED
|
@@ -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.
|
|
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.
|
|
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.
|
|
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.
|
|
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.
|
|
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.
|
|
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.
|
|
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.
|
|
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.
|
|
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.
|
|
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.
|
|
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.
|
|
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.
|
|
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;
|
package/dist/cjs/index.cjs.map
CHANGED
|
@@ -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":[]}
|
package/dist/index.legacy-esm.js
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.
|
|
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.
|
|
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.
|
|
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.
|
|
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.
|
|
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.
|
|
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.
|
|
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.
|
|
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.
|
|
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.
|
|
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.
|
|
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.
|
|
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.
|
|
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.
|
|
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.
|
|
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.
|
|
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.
|
|
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.
|
|
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.
|
|
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.
|
|
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.
|
|
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.
|
|
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.
|
|
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.
|
|
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.
|
|
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.
|
|
206
|
+
severity: DiagnosticSeverity.Hint,
|
|
207
207
|
range: toRange(ctx.document, stringNode)
|
|
208
208
|
});
|
|
209
209
|
return str;
|
package/dist/index.mjs.map
CHANGED
|
@@ -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
|
+
"version": "0.10.0-next.0",
|
|
10
10
|
"main": "dist/cjs/index.cjs",
|
|
11
11
|
"dependencies": {
|
|
12
|
-
"@player-tools/json-language-service": "0.
|
|
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",
|
package/src/complexity-check.ts
CHANGED
|
@@ -79,7 +79,7 @@ export class ComplexityCheck implements PlayerLanguageServicePlugin {
|
|
|
79
79
|
|
|
80
80
|
let diagnostic: Diagnostic = {
|
|
81
81
|
message: `${message}`,
|
|
82
|
-
severity: DiagnosticSeverity.
|
|
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.
|
|
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.
|
|
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.
|
|
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.
|
|
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.
|
|
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.
|
|
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.
|
|
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.
|
|
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.
|
|
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.
|
|
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.
|
|
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.
|
|
280
|
+
severity: DiagnosticSeverity.Hint,
|
|
281
281
|
range: toRange(ctx.document, stringNode),
|
|
282
282
|
});
|
|
283
283
|
|