@yohakuforce/core 0.4.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/README.md +65 -0
- package/dist/adapters/dx-mcp/dx-mcp-source-adapter.d.ts +25 -0
- package/dist/adapters/dx-mcp/dx-mcp-source-adapter.d.ts.map +1 -0
- package/dist/adapters/dx-mcp/dx-mcp-source-adapter.js +45 -0
- package/dist/adapters/dx-mcp/dx-mcp-source-adapter.js.map +1 -0
- package/dist/adapters/dx-mcp/index.d.ts +3 -0
- package/dist/adapters/dx-mcp/index.d.ts.map +1 -0
- package/dist/adapters/dx-mcp/index.js +2 -0
- package/dist/adapters/dx-mcp/index.js.map +1 -0
- package/dist/adapters/local/index.d.ts +5 -0
- package/dist/adapters/local/index.d.ts.map +1 -0
- package/dist/adapters/local/index.js +3 -0
- package/dist/adapters/local/index.js.map +1 -0
- package/dist/adapters/local/local-source-adapter.d.ts +19 -0
- package/dist/adapters/local/local-source-adapter.d.ts.map +1 -0
- package/dist/adapters/local/local-source-adapter.js +214 -0
- package/dist/adapters/local/local-source-adapter.js.map +1 -0
- package/dist/adapters/local/sfdx-project.d.ts +14 -0
- package/dist/adapters/local/sfdx-project.d.ts.map +1 -0
- package/dist/adapters/local/sfdx-project.js +76 -0
- package/dist/adapters/local/sfdx-project.js.map +1 -0
- package/dist/change-summary/index.d.ts +4 -0
- package/dist/change-summary/index.d.ts.map +1 -0
- package/dist/change-summary/index.js +3 -0
- package/dist/change-summary/index.js.map +1 -0
- package/dist/change-summary/schema.json +152 -0
- package/dist/change-summary/types.d.ts +52 -0
- package/dist/change-summary/types.d.ts.map +1 -0
- package/dist/change-summary/types.js +18 -0
- package/dist/change-summary/types.js.map +1 -0
- package/dist/change-summary/validate.d.ts +8 -0
- package/dist/change-summary/validate.d.ts.map +1 -0
- package/dist/change-summary/validate.js +35 -0
- package/dist/change-summary/validate.js.map +1 -0
- package/dist/cli.d.ts +3 -0
- package/dist/cli.d.ts.map +1 -0
- package/dist/cli.js +945 -0
- package/dist/cli.js.map +1 -0
- package/dist/consistency/check.d.ts +4 -0
- package/dist/consistency/check.d.ts.map +1 -0
- package/dist/consistency/check.js +70 -0
- package/dist/consistency/check.js.map +1 -0
- package/dist/consistency/index.d.ts +4 -0
- package/dist/consistency/index.d.ts.map +1 -0
- package/dist/consistency/index.js +3 -0
- package/dist/consistency/index.js.map +1 -0
- package/dist/consistency/types.d.ts +29 -0
- package/dist/consistency/types.d.ts.map +1 -0
- package/dist/consistency/types.js +12 -0
- package/dist/consistency/types.js.map +1 -0
- package/dist/diff/classify-files.d.ts +9 -0
- package/dist/diff/classify-files.d.ts.map +1 -0
- package/dist/diff/classify-files.js +105 -0
- package/dist/diff/classify-files.js.map +1 -0
- package/dist/diff/diff.d.ts +11 -0
- package/dist/diff/diff.d.ts.map +1 -0
- package/dist/diff/diff.js +69 -0
- package/dist/diff/diff.js.map +1 -0
- package/dist/diff/git.d.ts +28 -0
- package/dist/diff/git.d.ts.map +1 -0
- package/dist/diff/git.js +115 -0
- package/dist/diff/git.js.map +1 -0
- package/dist/diff/index.d.ts +7 -0
- package/dist/diff/index.d.ts.map +1 -0
- package/dist/diff/index.js +5 -0
- package/dist/diff/index.js.map +1 -0
- package/dist/diff/types.d.ts +28 -0
- package/dist/diff/types.d.ts.map +1 -0
- package/dist/diff/types.js +4 -0
- package/dist/diff/types.js.map +1 -0
- package/dist/explain/block-registry.d.ts +17 -0
- package/dist/explain/block-registry.d.ts.map +1 -0
- package/dist/explain/block-registry.js +73 -0
- package/dist/explain/block-registry.js.map +1 -0
- package/dist/explain/index.d.ts +22 -0
- package/dist/explain/index.d.ts.map +1 -0
- package/dist/explain/index.js +128 -0
- package/dist/explain/index.js.map +1 -0
- package/dist/graph/builder.d.ts +9 -0
- package/dist/graph/builder.d.ts.map +1 -0
- package/dist/graph/builder.js +276 -0
- package/dist/graph/builder.js.map +1 -0
- package/dist/graph/dependencies.d.ts +5 -0
- package/dist/graph/dependencies.d.ts.map +1 -0
- package/dist/graph/dependencies.js +38 -0
- package/dist/graph/dependencies.js.map +1 -0
- package/dist/graph/extractors/apex-body.d.ts +5 -0
- package/dist/graph/extractors/apex-body.d.ts.map +1 -0
- package/dist/graph/extractors/apex-body.js +289 -0
- package/dist/graph/extractors/apex-body.js.map +1 -0
- package/dist/graph/extractors/apex-class.d.ts +5 -0
- package/dist/graph/extractors/apex-class.d.ts.map +1 -0
- package/dist/graph/extractors/apex-class.js +43 -0
- package/dist/graph/extractors/apex-class.js.map +1 -0
- package/dist/graph/extractors/apex-control-flow.d.ts +33 -0
- package/dist/graph/extractors/apex-control-flow.d.ts.map +1 -0
- package/dist/graph/extractors/apex-control-flow.js +432 -0
- package/dist/graph/extractors/apex-control-flow.js.map +1 -0
- package/dist/graph/extractors/apex-trigger.d.ts +4 -0
- package/dist/graph/extractors/apex-trigger.d.ts.map +1 -0
- package/dist/graph/extractors/apex-trigger.js +40 -0
- package/dist/graph/extractors/apex-trigger.js.map +1 -0
- package/dist/graph/extractors/approval-process.d.ts +4 -0
- package/dist/graph/extractors/approval-process.d.ts.map +1 -0
- package/dist/graph/extractors/approval-process.js +103 -0
- package/dist/graph/extractors/approval-process.js.map +1 -0
- package/dist/graph/extractors/aura-bundle.d.ts +4 -0
- package/dist/graph/extractors/aura-bundle.d.ts.map +1 -0
- package/dist/graph/extractors/aura-bundle.js +77 -0
- package/dist/graph/extractors/aura-bundle.js.map +1 -0
- package/dist/graph/extractors/custom-application.d.ts +4 -0
- package/dist/graph/extractors/custom-application.d.ts.map +1 -0
- package/dist/graph/extractors/custom-application.js +55 -0
- package/dist/graph/extractors/custom-application.js.map +1 -0
- package/dist/graph/extractors/custom-metadata-record.d.ts +4 -0
- package/dist/graph/extractors/custom-metadata-record.d.ts.map +1 -0
- package/dist/graph/extractors/custom-metadata-record.js +53 -0
- package/dist/graph/extractors/custom-metadata-record.js.map +1 -0
- package/dist/graph/extractors/field.d.ts +4 -0
- package/dist/graph/extractors/field.d.ts.map +1 -0
- package/dist/graph/extractors/field.js +36 -0
- package/dist/graph/extractors/field.js.map +1 -0
- package/dist/graph/extractors/flexi-page.d.ts +4 -0
- package/dist/graph/extractors/flexi-page.d.ts.map +1 -0
- package/dist/graph/extractors/flexi-page.js +46 -0
- package/dist/graph/extractors/flexi-page.js.map +1 -0
- package/dist/graph/extractors/flow-body.d.ts +3 -0
- package/dist/graph/extractors/flow-body.d.ts.map +1 -0
- package/dist/graph/extractors/flow-body.js +144 -0
- package/dist/graph/extractors/flow-body.js.map +1 -0
- package/dist/graph/extractors/flow.d.ts +4 -0
- package/dist/graph/extractors/flow.d.ts.map +1 -0
- package/dist/graph/extractors/flow.js +20 -0
- package/dist/graph/extractors/flow.js.map +1 -0
- package/dist/graph/extractors/index.d.ts +24 -0
- package/dist/graph/extractors/index.d.ts.map +1 -0
- package/dist/graph/extractors/index.js +23 -0
- package/dist/graph/extractors/index.js.map +1 -0
- package/dist/graph/extractors/layout.d.ts +4 -0
- package/dist/graph/extractors/layout.d.ts.map +1 -0
- package/dist/graph/extractors/layout.js +89 -0
- package/dist/graph/extractors/layout.js.map +1 -0
- package/dist/graph/extractors/lwc.d.ts +4 -0
- package/dist/graph/extractors/lwc.d.ts.map +1 -0
- package/dist/graph/extractors/lwc.js +170 -0
- package/dist/graph/extractors/lwc.js.map +1 -0
- package/dist/graph/extractors/named-credential.d.ts +9 -0
- package/dist/graph/extractors/named-credential.d.ts.map +1 -0
- package/dist/graph/extractors/named-credential.js +38 -0
- package/dist/graph/extractors/named-credential.js.map +1 -0
- package/dist/graph/extractors/object.d.ts +4 -0
- package/dist/graph/extractors/object.d.ts.map +1 -0
- package/dist/graph/extractors/object.js +16 -0
- package/dist/graph/extractors/object.js.map +1 -0
- package/dist/graph/extractors/permission-set-body.d.ts +3 -0
- package/dist/graph/extractors/permission-set-body.d.ts.map +1 -0
- package/dist/graph/extractors/permission-set-body.js +80 -0
- package/dist/graph/extractors/permission-set-body.js.map +1 -0
- package/dist/graph/extractors/permission-set.d.ts +4 -0
- package/dist/graph/extractors/permission-set.d.ts.map +1 -0
- package/dist/graph/extractors/permission-set.js +17 -0
- package/dist/graph/extractors/permission-set.js.map +1 -0
- package/dist/graph/extractors/profile.d.ts +4 -0
- package/dist/graph/extractors/profile.d.ts.map +1 -0
- package/dist/graph/extractors/profile.js +15 -0
- package/dist/graph/extractors/profile.js.map +1 -0
- package/dist/graph/extractors/record-type.d.ts +4 -0
- package/dist/graph/extractors/record-type.d.ts.map +1 -0
- package/dist/graph/extractors/record-type.js +19 -0
- package/dist/graph/extractors/record-type.js.map +1 -0
- package/dist/graph/extractors/remote-site-setting.d.ts +4 -0
- package/dist/graph/extractors/remote-site-setting.d.ts.map +1 -0
- package/dist/graph/extractors/remote-site-setting.js +15 -0
- package/dist/graph/extractors/remote-site-setting.js.map +1 -0
- package/dist/graph/extractors/sharing-rules.d.ts +8 -0
- package/dist/graph/extractors/sharing-rules.d.ts.map +1 -0
- package/dist/graph/extractors/sharing-rules.js +122 -0
- package/dist/graph/extractors/sharing-rules.js.map +1 -0
- package/dist/graph/extractors/types.d.ts +8 -0
- package/dist/graph/extractors/types.d.ts.map +1 -0
- package/dist/graph/extractors/types.js +2 -0
- package/dist/graph/extractors/types.js.map +1 -0
- package/dist/graph/extractors/validation-rule.d.ts +4 -0
- package/dist/graph/extractors/validation-rule.d.ts.map +1 -0
- package/dist/graph/extractors/validation-rule.js +19 -0
- package/dist/graph/extractors/validation-rule.js.map +1 -0
- package/dist/graph/extractors/visualforce-component.d.ts +4 -0
- package/dist/graph/extractors/visualforce-component.d.ts.map +1 -0
- package/dist/graph/extractors/visualforce-component.js +90 -0
- package/dist/graph/extractors/visualforce-component.js.map +1 -0
- package/dist/graph/extractors/visualforce-page.d.ts +4 -0
- package/dist/graph/extractors/visualforce-page.d.ts.map +1 -0
- package/dist/graph/extractors/visualforce-page.js +92 -0
- package/dist/graph/extractors/visualforce-page.js.map +1 -0
- package/dist/graph/index.d.ts +8 -0
- package/dist/graph/index.d.ts.map +1 -0
- package/dist/graph/index.js +5 -0
- package/dist/graph/index.js.map +1 -0
- package/dist/graph/parse-xml.d.ts +5 -0
- package/dist/graph/parse-xml.d.ts.map +1 -0
- package/dist/graph/parse-xml.js +39 -0
- package/dist/graph/parse-xml.js.map +1 -0
- package/dist/graph/sqlite-reader.d.ts +33 -0
- package/dist/graph/sqlite-reader.d.ts.map +1 -0
- package/dist/graph/sqlite-reader.js +445 -0
- package/dist/graph/sqlite-reader.js.map +1 -0
- package/dist/graph/sqlite-store.d.ts +78 -0
- package/dist/graph/sqlite-store.d.ts.map +1 -0
- package/dist/graph/sqlite-store.js +683 -0
- package/dist/graph/sqlite-store.js.map +1 -0
- package/dist/index.d.ts +33 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +18 -0
- package/dist/index.js.map +1 -0
- package/dist/init/index.d.ts +4 -0
- package/dist/init/index.d.ts.map +1 -0
- package/dist/init/index.js +3 -0
- package/dist/init/index.js.map +1 -0
- package/dist/init/init.d.ts +9 -0
- package/dist/init/init.d.ts.map +1 -0
- package/dist/init/init.js +92 -0
- package/dist/init/init.js.map +1 -0
- package/dist/init/types.d.ts +37 -0
- package/dist/init/types.d.ts.map +1 -0
- package/dist/init/types.js +59 -0
- package/dist/init/types.js.map +1 -0
- package/dist/merge/index.d.ts +6 -0
- package/dist/merge/index.d.ts.map +1 -0
- package/dist/merge/index.js +5 -0
- package/dist/merge/index.js.map +1 -0
- package/dist/merge/markers.d.ts +8 -0
- package/dist/merge/markers.d.ts.map +1 -0
- package/dist/merge/markers.js +30 -0
- package/dist/merge/markers.js.map +1 -0
- package/dist/merge/merge.d.ts +12 -0
- package/dist/merge/merge.d.ts.map +1 -0
- package/dist/merge/merge.js +116 -0
- package/dist/merge/merge.js.map +1 -0
- package/dist/merge/parser.d.ts +5 -0
- package/dist/merge/parser.d.ts.map +1 -0
- package/dist/merge/parser.js +63 -0
- package/dist/merge/parser.js.map +1 -0
- package/dist/merge/validator.d.ts +15 -0
- package/dist/merge/validator.d.ts.map +1 -0
- package/dist/merge/validator.js +64 -0
- package/dist/merge/validator.js.map +1 -0
- package/dist/metrics/aggregate.d.ts +11 -0
- package/dist/metrics/aggregate.d.ts.map +1 -0
- package/dist/metrics/aggregate.js +51 -0
- package/dist/metrics/aggregate.js.map +1 -0
- package/dist/metrics/index.d.ts +7 -0
- package/dist/metrics/index.d.ts.map +1 -0
- package/dist/metrics/index.js +4 -0
- package/dist/metrics/index.js.map +1 -0
- package/dist/metrics/store.d.ts +19 -0
- package/dist/metrics/store.d.ts.map +1 -0
- package/dist/metrics/store.js +69 -0
- package/dist/metrics/store.js.map +1 -0
- package/dist/metrics/types.d.ts +32 -0
- package/dist/metrics/types.d.ts.map +1 -0
- package/dist/metrics/types.js +38 -0
- package/dist/metrics/types.js.map +1 -0
- package/dist/onboarding/context-map.d.ts +15 -0
- package/dist/onboarding/context-map.d.ts.map +1 -0
- package/dist/onboarding/context-map.js +138 -0
- package/dist/onboarding/context-map.js.map +1 -0
- package/dist/onboarding/faq.d.ts +24 -0
- package/dist/onboarding/faq.d.ts.map +1 -0
- package/dist/onboarding/faq.js +127 -0
- package/dist/onboarding/faq.js.map +1 -0
- package/dist/onboarding/index.d.ts +9 -0
- package/dist/onboarding/index.d.ts.map +1 -0
- package/dist/onboarding/index.js +5 -0
- package/dist/onboarding/index.js.map +1 -0
- package/dist/onboarding/state.d.ts +15 -0
- package/dist/onboarding/state.d.ts.map +1 -0
- package/dist/onboarding/state.js +92 -0
- package/dist/onboarding/state.js.map +1 -0
- package/dist/onboarding/types.d.ts +38 -0
- package/dist/onboarding/types.d.ts.map +1 -0
- package/dist/onboarding/types.js +13 -0
- package/dist/onboarding/types.js.map +1 -0
- package/dist/release/extract-manual-steps.d.ts +16 -0
- package/dist/release/extract-manual-steps.d.ts.map +1 -0
- package/dist/release/extract-manual-steps.js +164 -0
- package/dist/release/extract-manual-steps.js.map +1 -0
- package/dist/release/index.d.ts +4 -0
- package/dist/release/index.d.ts.map +1 -0
- package/dist/release/index.js +3 -0
- package/dist/release/index.js.map +1 -0
- package/dist/release/schema.json +142 -0
- package/dist/release/types.d.ts +39 -0
- package/dist/release/types.d.ts.map +1 -0
- package/dist/release/types.js +4 -0
- package/dist/release/types.js.map +1 -0
- package/dist/release/validate.d.ts +8 -0
- package/dist/release/validate.d.ts.map +1 -0
- package/dist/release/validate.js +35 -0
- package/dist/release/validate.js.map +1 -0
- package/dist/render/approval-mermaid.d.ts +3 -0
- package/dist/render/approval-mermaid.d.ts.map +1 -0
- package/dist/render/approval-mermaid.js +69 -0
- package/dist/render/approval-mermaid.js.map +1 -0
- package/dist/render/archive.d.ts +2 -0
- package/dist/render/archive.d.ts.map +1 -0
- package/dist/render/archive.js +32 -0
- package/dist/render/archive.js.map +1 -0
- package/dist/render/concerns.d.ts +11 -0
- package/dist/render/concerns.d.ts.map +1 -0
- package/dist/render/concerns.js +83 -0
- package/dist/render/concerns.js.map +1 -0
- package/dist/render/er-diagram.d.ts +3 -0
- package/dist/render/er-diagram.d.ts.map +1 -0
- package/dist/render/er-diagram.js +79 -0
- package/dist/render/er-diagram.js.map +1 -0
- package/dist/render/eta-engine.d.ts +2 -0
- package/dist/render/eta-engine.d.ts.map +1 -0
- package/dist/render/eta-engine.js +39 -0
- package/dist/render/eta-engine.js.map +1 -0
- package/dist/render/flow-flowchart.d.ts +4 -0
- package/dist/render/flow-flowchart.d.ts.map +1 -0
- package/dist/render/flow-flowchart.js +59 -0
- package/dist/render/flow-flowchart.js.map +1 -0
- package/dist/render/flow-sequence-table.d.ts +11 -0
- package/dist/render/flow-sequence-table.d.ts.map +1 -0
- package/dist/render/flow-sequence-table.js +88 -0
- package/dist/render/flow-sequence-table.js.map +1 -0
- package/dist/render/formula.d.ts +33 -0
- package/dist/render/formula.d.ts.map +1 -0
- package/dist/render/formula.js +381 -0
- package/dist/render/formula.js.map +1 -0
- package/dist/render/index.d.ts +6 -0
- package/dist/render/index.d.ts.map +1 -0
- package/dist/render/index.js +5 -0
- package/dist/render/index.js.map +1 -0
- package/dist/render/intra-class-call-graph.d.ts +3 -0
- package/dist/render/intra-class-call-graph.d.ts.map +1 -0
- package/dist/render/intra-class-call-graph.js +32 -0
- package/dist/render/intra-class-call-graph.js.map +1 -0
- package/dist/render/mermaid.d.ts +6 -0
- package/dist/render/mermaid.d.ts.map +1 -0
- package/dist/render/mermaid.js +99 -0
- package/dist/render/mermaid.js.map +1 -0
- package/dist/render/method-flowchart.d.ts +15 -0
- package/dist/render/method-flowchart.d.ts.map +1 -0
- package/dist/render/method-flowchart.js +232 -0
- package/dist/render/method-flowchart.js.map +1 -0
- package/dist/render/method-summary-table.d.ts +17 -0
- package/dist/render/method-summary-table.d.ts.map +1 -0
- package/dist/render/method-summary-table.js +189 -0
- package/dist/render/method-summary-table.js.map +1 -0
- package/dist/render/render.d.ts +37 -0
- package/dist/render/render.d.ts.map +1 -0
- package/dist/render/render.js +491 -0
- package/dist/render/render.js.map +1 -0
- package/dist/render/summary.d.ts +21 -0
- package/dist/render/summary.d.ts.map +1 -0
- package/dist/render/summary.js +542 -0
- package/dist/render/summary.js.map +1 -0
- package/dist/render/templates/apex-class.eta +204 -0
- package/dist/render/templates/apex-trigger.eta +143 -0
- package/dist/render/templates/approval-process.eta +118 -0
- package/dist/render/templates/aura-bundle.eta +47 -0
- package/dist/render/templates/custom-application.eta +44 -0
- package/dist/render/templates/custom-metadata-record.eta +37 -0
- package/dist/render/templates/executive-risks.eta +56 -0
- package/dist/render/templates/executive-summary.eta +68 -0
- package/dist/render/templates/flexi-page.eta +47 -0
- package/dist/render/templates/flow.eta +166 -0
- package/dist/render/templates/layout.eta +68 -0
- package/dist/render/templates/lwc.eta +118 -0
- package/dist/render/templates/named-credential.eta +30 -0
- package/dist/render/templates/object.eta +68 -0
- package/dist/render/templates/permission-set.eta +80 -0
- package/dist/render/templates/profile.eta +78 -0
- package/dist/render/templates/record-type.eta +23 -0
- package/dist/render/templates/remote-site-setting.eta +23 -0
- package/dist/render/templates/sharing-rule.eta +50 -0
- package/dist/render/templates/system-index.eta +52 -0
- package/dist/render/templates/system-overview.eta +37 -0
- package/dist/render/templates/validation-rule.eta +55 -0
- package/dist/render/templates/visualforce-component.eta +52 -0
- package/dist/render/templates/visualforce-page.eta +76 -0
- package/dist/render/trigger-processing-summary.d.ts +12 -0
- package/dist/render/trigger-processing-summary.d.ts.map +1 -0
- package/dist/render/trigger-processing-summary.js +94 -0
- package/dist/render/trigger-processing-summary.js.map +1 -0
- package/dist/sarif/index.d.ts +3 -0
- package/dist/sarif/index.d.ts.map +1 -0
- package/dist/sarif/index.js +2 -0
- package/dist/sarif/index.js.map +1 -0
- package/dist/sarif/parse.d.ts +7 -0
- package/dist/sarif/parse.d.ts.map +1 -0
- package/dist/sarif/parse.js +55 -0
- package/dist/sarif/parse.js.map +1 -0
- package/dist/sarif/types.d.ts +43 -0
- package/dist/sarif/types.d.ts.map +1 -0
- package/dist/sarif/types.js +4 -0
- package/dist/sarif/types.js.map +1 -0
- package/dist/scaffold/.agents/README.md +12 -0
- package/dist/scaffold/.agents/knowledge/INDEX.md +52 -0
- package/dist/scaffold/.agents/knowledge/README.md +29 -0
- package/dist/scaffold/.agents/knowledge/decisions/.gitkeep +0 -0
- package/dist/scaffold/.agents/knowledge/improvements/.gitkeep +0 -0
- package/dist/scaffold/.agents/knowledge/pitfalls/.gitkeep +0 -0
- package/dist/scaffold/.agents/knowledge/retrospectives/.gitkeep +0 -0
- package/dist/scaffold/.agents/knowledge/wins/.gitkeep +0 -0
- package/dist/scaffold/.agents/templates/.gitkeep +0 -0
- package/dist/scaffold/.agents/templates/README.md +19 -0
- package/dist/scaffold/.agents/templates/decision.md +39 -0
- package/dist/scaffold/.agents/templates/improvement.md +33 -0
- package/dist/scaffold/.agents/templates/pitfall.md +33 -0
- package/dist/scaffold/.agents/templates/retrospective.md +61 -0
- package/dist/scaffold/.agents/templates/win.md +28 -0
- package/dist/scaffold/.claude/README.md +11 -0
- package/dist/scaffold/.claude/agents/.gitkeep +0 -0
- package/dist/scaffold/.claude/agents/apex-query-tracer.md.eta +199 -0
- package/dist/scaffold/.claude/agents/automation-classifier.md.eta +39 -0
- package/dist/scaffold/.claude/agents/batch-calculator.md.eta +209 -0
- package/dist/scaffold/.claude/agents/cascade-tracer.md.eta +139 -0
- package/dist/scaffold/.claude/agents/customer-impact-explainer.md.eta +96 -0
- package/dist/scaffold/.claude/agents/data-model-classifier.md.eta +84 -0
- package/dist/scaffold/.claude/agents/explain-writer.md.eta +104 -0
- package/dist/scaffold/.claude/agents/flow-query-tracer.md.eta +211 -0
- package/dist/scaffold/.claude/agents/graph-querier.md.eta +47 -0
- package/dist/scaffold/.claude/agents/logic-classifier.md.eta +36 -0
- package/dist/scaffold/.claude/agents/manual-step-extractor.md.eta +72 -0
- package/dist/scaffold/.claude/agents/object-documenter.md.eta +66 -0
- package/dist/scaffold/.claude/agents/onboarding-guide.md.eta +77 -0
- package/dist/scaffold/.claude/agents/permission-classifier.md.eta +32 -0
- package/dist/scaffold/.claude/agents/release-advisor.md.eta +96 -0
- package/dist/scaffold/.claude/agents/release-composer.md.eta +106 -0
- package/dist/scaffold/.claude/agents/review-assistant.md.eta +72 -0
- package/dist/scaffold/.claude/agents/rollback-drafter.md.eta +95 -0
- package/dist/scaffold/.claude/agents/ui-classifier.md.eta +31 -0
- package/dist/scaffold/.claude/commands/.gitkeep +0 -0
- package/dist/scaffold/.claude/commands/analyze-batch-limits.md.eta +309 -0
- package/dist/scaffold/.claude/commands/change-summary.md.eta +79 -0
- package/dist/scaffold/.claude/commands/classify-diff.md.eta +107 -0
- package/dist/scaffold/.claude/commands/explain.md.eta +63 -0
- package/dist/scaffold/.claude/commands/impact.md.eta +67 -0
- package/dist/scaffold/.claude/commands/manual-steps.md.eta +62 -0
- package/dist/scaffold/.claude/commands/onboard.md.eta +107 -0
- package/dist/scaffold/.claude/commands/release-prep.md.eta +147 -0
- package/dist/scaffold/.claude/commands/yohaku-explain.md.eta +81 -0
- package/dist/scaffold/.claude/settings.json.eta +59 -0
- package/dist/scaffold/.yohaku/context-map.yaml.eta +56 -0
- package/dist/scaffold/.yohaku/secrets-rules.yaml.eta +44 -0
- package/dist/scaffold/AGENTS.md.eta +147 -0
- package/dist/scaffold/CLAUDE.md.eta +121 -0
- package/dist/scaffold/README.md +37 -0
- package/dist/schema/graph.schema.json +446 -0
- package/dist/schema/validate.d.ts +8 -0
- package/dist/schema/validate.d.ts.map +1 -0
- package/dist/schema/validate.js +49 -0
- package/dist/schema/validate.js.map +1 -0
- package/dist/secrets/apply.d.ts +17 -0
- package/dist/secrets/apply.d.ts.map +1 -0
- package/dist/secrets/apply.js +44 -0
- package/dist/secrets/apply.js.map +1 -0
- package/dist/secrets/index.d.ts +7 -0
- package/dist/secrets/index.d.ts.map +1 -0
- package/dist/secrets/index.js +4 -0
- package/dist/secrets/index.js.map +1 -0
- package/dist/secrets/load.d.ts +16 -0
- package/dist/secrets/load.d.ts.map +1 -0
- package/dist/secrets/load.js +136 -0
- package/dist/secrets/load.js.map +1 -0
- package/dist/secrets/mask.d.ts +15 -0
- package/dist/secrets/mask.d.ts.map +1 -0
- package/dist/secrets/mask.js +34 -0
- package/dist/secrets/mask.js.map +1 -0
- package/dist/secrets/rules.d.ts +10 -0
- package/dist/secrets/rules.d.ts.map +1 -0
- package/dist/secrets/rules.js +47 -0
- package/dist/secrets/rules.js.map +1 -0
- package/dist/types/graph.d.ts +508 -0
- package/dist/types/graph.d.ts.map +1 -0
- package/dist/types/graph.js +9 -0
- package/dist/types/graph.js.map +1 -0
- package/dist/types/render.d.ts +26 -0
- package/dist/types/render.d.ts.map +1 -0
- package/dist/types/render.js +10 -0
- package/dist/types/render.js.map +1 -0
- package/dist/types/source-adapter.d.ts +26 -0
- package/dist/types/source-adapter.d.ts.map +1 -0
- package/dist/types/source-adapter.js +11 -0
- package/dist/types/source-adapter.js.map +1 -0
- package/dist/util/build-lock.d.ts +35 -0
- package/dist/util/build-lock.d.ts.map +1 -0
- package/dist/util/build-lock.js +72 -0
- package/dist/util/build-lock.js.map +1 -0
- package/dist/util/hash.d.ts +3 -0
- package/dist/util/hash.d.ts.map +1 -0
- package/dist/util/hash.js +13 -0
- package/dist/util/hash.js.map +1 -0
- package/dist/util/path-guard.d.ts +16 -0
- package/dist/util/path-guard.d.ts.map +1 -0
- package/dist/util/path-guard.js +40 -0
- package/dist/util/path-guard.js.map +1 -0
- package/dist/util/timing-log.d.ts +28 -0
- package/dist/util/timing-log.d.ts.map +1 -0
- package/dist/util/timing-log.js +38 -0
- package/dist/util/timing-log.js.map +1 -0
- package/dist/util/walk.d.ts +10 -0
- package/dist/util/walk.d.ts.map +1 -0
- package/dist/util/walk.js +45 -0
- package/dist/util/walk.js.map +1 -0
- package/package.json +48 -0
- package/src/schema/graph.schema.json +446 -0
- package/src/schema/validate.ts +57 -0
|
@@ -0,0 +1,38 @@
|
|
|
1
|
+
export function deriveFieldDependencies(fields) {
|
|
2
|
+
const deps = [];
|
|
3
|
+
for (const field of fields) {
|
|
4
|
+
if (field.referenceTo === undefined)
|
|
5
|
+
continue;
|
|
6
|
+
for (const target of field.referenceTo) {
|
|
7
|
+
deps.push({
|
|
8
|
+
from: { kind: "field", fullyQualifiedName: field.fullyQualifiedName },
|
|
9
|
+
to: { kind: "object", fullyQualifiedName: target },
|
|
10
|
+
kind: "references",
|
|
11
|
+
evidencePath: field.sourcePath,
|
|
12
|
+
});
|
|
13
|
+
}
|
|
14
|
+
}
|
|
15
|
+
return deps;
|
|
16
|
+
}
|
|
17
|
+
export function deriveTriggerDependencies(triggers) {
|
|
18
|
+
return triggers.map((t) => ({
|
|
19
|
+
from: { kind: "apexTrigger", fullyQualifiedName: t.fullyQualifiedName },
|
|
20
|
+
to: { kind: "object", fullyQualifiedName: t.object },
|
|
21
|
+
kind: "triggers",
|
|
22
|
+
evidencePath: t.sourcePath,
|
|
23
|
+
}));
|
|
24
|
+
}
|
|
25
|
+
export function deriveFlowDependencies(flows) {
|
|
26
|
+
return flows
|
|
27
|
+
.filter((f) => f.triggeringObject !== undefined)
|
|
28
|
+
.map((f) => ({
|
|
29
|
+
from: { kind: "flow", fullyQualifiedName: f.fullyQualifiedName },
|
|
30
|
+
to: {
|
|
31
|
+
kind: "object",
|
|
32
|
+
fullyQualifiedName: f.triggeringObject,
|
|
33
|
+
},
|
|
34
|
+
kind: "triggers",
|
|
35
|
+
evidencePath: f.sourcePath,
|
|
36
|
+
}));
|
|
37
|
+
}
|
|
38
|
+
//# sourceMappingURL=dependencies.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"dependencies.js","sourceRoot":"","sources":["../../src/graph/dependencies.ts"],"names":[],"mappings":"AAEA,MAAM,UAAU,uBAAuB,CAAC,MAAwB;IAC9D,MAAM,IAAI,GAAiB,EAAE,CAAC;IAC9B,KAAK,MAAM,KAAK,IAAI,MAAM,EAAE,CAAC;QAC3B,IAAI,KAAK,CAAC,WAAW,KAAK,SAAS;YAAE,SAAS;QAC9C,KAAK,MAAM,MAAM,IAAI,KAAK,CAAC,WAAW,EAAE,CAAC;YACvC,IAAI,CAAC,IAAI,CAAC;gBACR,IAAI,EAAE,EAAE,IAAI,EAAE,OAAO,EAAE,kBAAkB,EAAE,KAAK,CAAC,kBAAkB,EAAE;gBACrE,EAAE,EAAE,EAAE,IAAI,EAAE,QAAQ,EAAE,kBAAkB,EAAE,MAAM,EAAE;gBAClD,IAAI,EAAE,YAAY;gBAClB,YAAY,EAAE,KAAK,CAAC,UAAU;aAC/B,CAAC,CAAC;QACL,CAAC;IACH,CAAC;IACD,OAAO,IAAI,CAAC;AACd,CAAC;AAED,MAAM,UAAU,yBAAyB,CAAC,QAAgC;IACxE,OAAO,QAAQ,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC;QAC1B,IAAI,EAAE,EAAE,IAAI,EAAE,aAAa,EAAE,kBAAkB,EAAE,CAAC,CAAC,kBAAkB,EAAE;QACvE,EAAE,EAAE,EAAE,IAAI,EAAE,QAAQ,EAAE,kBAAkB,EAAE,CAAC,CAAC,MAAM,EAAE;QACpD,IAAI,EAAE,UAAmB;QACzB,YAAY,EAAE,CAAC,CAAC,UAAU;KAC3B,CAAC,CAAC,CAAC;AACN,CAAC;AAED,MAAM,UAAU,sBAAsB,CAAC,KAAsB;IAC3D,OAAO,KAAK;SACT,MAAM,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,gBAAgB,KAAK,SAAS,CAAC;SAC/C,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC;QACX,IAAI,EAAE,EAAE,IAAI,EAAE,MAAe,EAAE,kBAAkB,EAAE,CAAC,CAAC,kBAAkB,EAAE;QACzE,EAAE,EAAE;YACF,IAAI,EAAE,QAAiB;YACvB,kBAAkB,EAAE,CAAC,CAAC,gBAA0B;SACjD;QACD,IAAI,EAAE,UAAmB;QACzB,YAAY,EAAE,CAAC,CAAC,UAAU;KAC3B,CAAC,CAAC,CAAC;AACR,CAAC"}
|
|
@@ -0,0 +1,5 @@
|
|
|
1
|
+
import type { ApexBodyInfo } from "../../types/graph.js";
|
|
2
|
+
/** コメント・文字列リテラルを除去して解析対象を整える */
|
|
3
|
+
export declare function stripApexNoise(content: string): string;
|
|
4
|
+
export declare function extractApexBody(rawContent: string): ApexBodyInfo;
|
|
5
|
+
//# sourceMappingURL=apex-body.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"apex-body.d.ts","sourceRoot":"","sources":["../../../src/graph/extractors/apex-body.ts"],"names":[],"mappings":"AAIA,OAAO,KAAK,EACV,YAAY,EAOb,MAAM,sBAAsB,CAAC;AA8B9B,gCAAgC;AAChC,wBAAgB,cAAc,CAAC,OAAO,EAAE,MAAM,GAAG,MAAM,CAKtD;AAOD,wBAAgB,eAAe,CAAC,UAAU,EAAE,MAAM,GAAG,YAAY,CAoBhE"}
|
|
@@ -0,0 +1,289 @@
|
|
|
1
|
+
// Apex .cls 本体の構造解析 (Phase 7-A+1)
|
|
2
|
+
// 正規表現ベース。AST 解析は Phase 7 後半 / Phase 8 で検討。
|
|
3
|
+
// 限界 (動的 SOQL 文字列、複雑な型) は HUMAN_MANAGED で補完前提。
|
|
4
|
+
const COMMENT_LINE_REGEX = /\/\/[^\n]*/g;
|
|
5
|
+
const COMMENT_BLOCK_REGEX = /\/\*[\s\S]*?\*\//g;
|
|
6
|
+
const STRING_LITERAL_REGEX = /'(?:\\.|[^'\\])*'/g;
|
|
7
|
+
const ANNOTATION_LINE_REGEX = /^\s*@(\w+(?:\([^)]*\))?)/gm;
|
|
8
|
+
// メソッド検出: 可視性 + (static)? + 戻り値 + 名前 + (引数)
|
|
9
|
+
// 戻り値は List<X>, Map<X,Y>, X[] 等を含む
|
|
10
|
+
const METHOD_REGEX = /(?:^|\n)\s*(public|private|protected|global)\s+(?:(static|virtual|abstract|override)\s+)*([\w<>,\s\?\[\]]+?)\s+(\w+)\s*\(([^)]*)\)\s*[{;]/gm;
|
|
11
|
+
const SOQL_REGEX = /\[\s*(SELECT[\s\S]+?FROM\s+\w+[\s\S]*?)\]/gi;
|
|
12
|
+
const SOQL_FROM_REGEX = /FROM\s+(\w+)/i;
|
|
13
|
+
const DML_VERB_REGEX = /(?:^|[\s;{])\s*(insert|update|delete|upsert|undelete|merge)\s+([a-zA-Z_]\w*)/gi;
|
|
14
|
+
const DATABASE_DML_REGEX = /Database\.(insert|update|delete|upsert|undelete|merge)\s*\(\s*([\w.]+)/gi;
|
|
15
|
+
const CLASS_REF_REGEX = /\b([A-Z][\w]*)\.([\w]+)\s*\(/g;
|
|
16
|
+
// new ClassName(...) — handler パターン (`new XHandler().run()`) を検出する
|
|
17
|
+
const NEW_INSTANCE_REGEX = /\bnew\s+([A-Z][\w]*)\s*\(/g;
|
|
18
|
+
const TRY_REGEX = /\btry\s*\{/;
|
|
19
|
+
const CALLOUT_REGEX = /\bnew\s+HttpRequest\s*\(|@HttpGet\b|@HttpPost\b|@HttpPut\b|@HttpDelete\b|@HttpPatch\b/;
|
|
20
|
+
/** コメント・文字列リテラルを除去して解析対象を整える */
|
|
21
|
+
export function stripApexNoise(content) {
|
|
22
|
+
return content
|
|
23
|
+
.replace(COMMENT_BLOCK_REGEX, " ")
|
|
24
|
+
.replace(COMMENT_LINE_REGEX, " ")
|
|
25
|
+
.replace(STRING_LITERAL_REGEX, "''");
|
|
26
|
+
}
|
|
27
|
+
/** 旧シンボル名 (内部互換用) */
|
|
28
|
+
function strip(content) {
|
|
29
|
+
return stripApexNoise(content);
|
|
30
|
+
}
|
|
31
|
+
export function extractApexBody(rawContent) {
|
|
32
|
+
const stripped = strip(rawContent);
|
|
33
|
+
const methods = extractMethods(stripped, rawContent);
|
|
34
|
+
const soqlQueries = extractSoql(stripped);
|
|
35
|
+
const dmlOperations = extractDml(stripped);
|
|
36
|
+
const classReferences = extractClassReferences(stripped);
|
|
37
|
+
const classAnnotations = extractClassAnnotations(rawContent);
|
|
38
|
+
const hasTryCatch = TRY_REGEX.test(stripped);
|
|
39
|
+
const hasCallout = CALLOUT_REGEX.test(rawContent);
|
|
40
|
+
return {
|
|
41
|
+
methods,
|
|
42
|
+
soqlQueries,
|
|
43
|
+
dmlOperations,
|
|
44
|
+
classReferences,
|
|
45
|
+
classAnnotations,
|
|
46
|
+
hasTryCatch,
|
|
47
|
+
hasCallout,
|
|
48
|
+
};
|
|
49
|
+
}
|
|
50
|
+
function extractMethods(stripped, raw) {
|
|
51
|
+
const result = [];
|
|
52
|
+
const re = new RegExp(METHOD_REGEX.source, "gm");
|
|
53
|
+
let match = re.exec(stripped);
|
|
54
|
+
while (match !== null) {
|
|
55
|
+
const visibility = match[1];
|
|
56
|
+
const modifier = match[2] ?? "";
|
|
57
|
+
const isStatic = modifier === "static";
|
|
58
|
+
const returnType = (match[3] ?? "").trim().replace(/\s+/g, " ");
|
|
59
|
+
const name = match[4] ?? "";
|
|
60
|
+
const parameters = (match[5] ?? "").trim();
|
|
61
|
+
// 戻り値が void は許容する。control-flow キーワード (if/while/for/switch...) のみを排除。
|
|
62
|
+
if (returnType === "" ||
|
|
63
|
+
name === "" ||
|
|
64
|
+
isControlFlowKeyword(returnType) ||
|
|
65
|
+
isReservedKeyword(name)) {
|
|
66
|
+
match = re.exec(stripped);
|
|
67
|
+
continue;
|
|
68
|
+
}
|
|
69
|
+
// メソッド直前のアノテーションを raw から取得
|
|
70
|
+
const annotations = extractMethodAnnotations(raw, name);
|
|
71
|
+
result.push({ name, visibility, isStatic, returnType, parameters, annotations });
|
|
72
|
+
match = re.exec(stripped);
|
|
73
|
+
}
|
|
74
|
+
return dedupeMethods(result);
|
|
75
|
+
}
|
|
76
|
+
function dedupeMethods(methods) {
|
|
77
|
+
const seen = new Set();
|
|
78
|
+
const result = [];
|
|
79
|
+
for (const m of methods) {
|
|
80
|
+
const key = `${m.name}(${m.parameters})`;
|
|
81
|
+
if (seen.has(key))
|
|
82
|
+
continue;
|
|
83
|
+
seen.add(key);
|
|
84
|
+
result.push(m);
|
|
85
|
+
}
|
|
86
|
+
return result;
|
|
87
|
+
}
|
|
88
|
+
function extractMethodAnnotations(raw, methodName) {
|
|
89
|
+
// method 宣言の直前 5 行までに現れる @AAA を拾う簡易実装
|
|
90
|
+
const lines = raw.split("\n");
|
|
91
|
+
const idx = lines.findIndex((line) => new RegExp(`\\b${methodName}\\s*\\(`).test(line));
|
|
92
|
+
if (idx === -1)
|
|
93
|
+
return [];
|
|
94
|
+
const before = lines.slice(Math.max(0, idx - 5), idx);
|
|
95
|
+
const annotations = [];
|
|
96
|
+
for (const line of before) {
|
|
97
|
+
const m = /^\s*@(\w+(?:\([^)]*\))?)/.exec(line);
|
|
98
|
+
if (m?.[1])
|
|
99
|
+
annotations.push(m[1]);
|
|
100
|
+
}
|
|
101
|
+
return annotations;
|
|
102
|
+
}
|
|
103
|
+
function extractClassAnnotations(raw) {
|
|
104
|
+
const annotations = [];
|
|
105
|
+
const re = new RegExp(ANNOTATION_LINE_REGEX.source, "gm");
|
|
106
|
+
let match = re.exec(raw);
|
|
107
|
+
// クラス宣言行までに現れる @AAA をクラスアノテーションと見做す
|
|
108
|
+
const classDeclIdx = raw.search(/\b(class|interface|enum)\s+\w+/);
|
|
109
|
+
while (match !== null) {
|
|
110
|
+
if (classDeclIdx !== -1 && match.index > classDeclIdx)
|
|
111
|
+
break;
|
|
112
|
+
if (match[1])
|
|
113
|
+
annotations.push(match[1]);
|
|
114
|
+
match = re.exec(raw);
|
|
115
|
+
}
|
|
116
|
+
return annotations;
|
|
117
|
+
}
|
|
118
|
+
function extractSoql(stripped) {
|
|
119
|
+
const result = [];
|
|
120
|
+
const re = new RegExp(SOQL_REGEX.source, "gi");
|
|
121
|
+
let match = re.exec(stripped);
|
|
122
|
+
while (match !== null) {
|
|
123
|
+
const raw = (match[1] ?? "").trim().replace(/\s+/g, " ");
|
|
124
|
+
const fromMatch = SOQL_FROM_REGEX.exec(raw);
|
|
125
|
+
const primaryObject = fromMatch?.[1] ?? null;
|
|
126
|
+
result.push({ raw, primaryObject });
|
|
127
|
+
match = re.exec(stripped);
|
|
128
|
+
}
|
|
129
|
+
return result;
|
|
130
|
+
}
|
|
131
|
+
function extractDml(stripped) {
|
|
132
|
+
const result = [];
|
|
133
|
+
const verbRe = new RegExp(DML_VERB_REGEX.source, "gi");
|
|
134
|
+
let m1 = verbRe.exec(stripped);
|
|
135
|
+
while (m1 !== null) {
|
|
136
|
+
const kind = (m1[1] ?? "").toLowerCase();
|
|
137
|
+
const target = m1[2] ?? "";
|
|
138
|
+
if (target !== "" && !isReservedKeyword(target)) {
|
|
139
|
+
result.push({ kind, target, viaDatabaseClass: false });
|
|
140
|
+
}
|
|
141
|
+
m1 = verbRe.exec(stripped);
|
|
142
|
+
}
|
|
143
|
+
const dbRe = new RegExp(DATABASE_DML_REGEX.source, "gi");
|
|
144
|
+
let m2 = dbRe.exec(stripped);
|
|
145
|
+
while (m2 !== null) {
|
|
146
|
+
const kind = (m2[1] ?? "").toLowerCase();
|
|
147
|
+
const target = m2[2] ?? "";
|
|
148
|
+
if (target !== "") {
|
|
149
|
+
result.push({ kind, target, viaDatabaseClass: true });
|
|
150
|
+
}
|
|
151
|
+
m2 = dbRe.exec(stripped);
|
|
152
|
+
}
|
|
153
|
+
return result;
|
|
154
|
+
}
|
|
155
|
+
function extractClassReferences(stripped) {
|
|
156
|
+
const result = [];
|
|
157
|
+
const seen = new Set();
|
|
158
|
+
const re = new RegExp(CLASS_REF_REGEX.source, "g");
|
|
159
|
+
let match = re.exec(stripped);
|
|
160
|
+
while (match !== null) {
|
|
161
|
+
const className = match[1] ?? "";
|
|
162
|
+
const memberName = match[2] ?? "";
|
|
163
|
+
if (className === "" || memberName === "") {
|
|
164
|
+
match = re.exec(stripped);
|
|
165
|
+
continue;
|
|
166
|
+
}
|
|
167
|
+
if (isReservedKeyword(className) || isStandardApexType(className)) {
|
|
168
|
+
match = re.exec(stripped);
|
|
169
|
+
continue;
|
|
170
|
+
}
|
|
171
|
+
const key = `${className}.${memberName}`;
|
|
172
|
+
if (!seen.has(key)) {
|
|
173
|
+
seen.add(key);
|
|
174
|
+
result.push({ className, memberName });
|
|
175
|
+
}
|
|
176
|
+
match = re.exec(stripped);
|
|
177
|
+
}
|
|
178
|
+
const newRe = new RegExp(NEW_INSTANCE_REGEX.source, "g");
|
|
179
|
+
let nm = newRe.exec(stripped);
|
|
180
|
+
while (nm !== null) {
|
|
181
|
+
const className = nm[1] ?? "";
|
|
182
|
+
if (className === "" || isReservedKeyword(className) || isStandardApexType(className)) {
|
|
183
|
+
nm = newRe.exec(stripped);
|
|
184
|
+
continue;
|
|
185
|
+
}
|
|
186
|
+
const key = `${className}.<new>`;
|
|
187
|
+
if (!seen.has(key)) {
|
|
188
|
+
seen.add(key);
|
|
189
|
+
result.push({ className, memberName: "<new>" });
|
|
190
|
+
}
|
|
191
|
+
nm = newRe.exec(stripped);
|
|
192
|
+
}
|
|
193
|
+
return result;
|
|
194
|
+
}
|
|
195
|
+
const RESERVED = new Set([
|
|
196
|
+
"if",
|
|
197
|
+
"else",
|
|
198
|
+
"for",
|
|
199
|
+
"while",
|
|
200
|
+
"do",
|
|
201
|
+
"switch",
|
|
202
|
+
"return",
|
|
203
|
+
"throw",
|
|
204
|
+
"try",
|
|
205
|
+
"catch",
|
|
206
|
+
"finally",
|
|
207
|
+
"new",
|
|
208
|
+
"this",
|
|
209
|
+
"super",
|
|
210
|
+
"true",
|
|
211
|
+
"false",
|
|
212
|
+
"null",
|
|
213
|
+
"void",
|
|
214
|
+
"static",
|
|
215
|
+
"final",
|
|
216
|
+
"public",
|
|
217
|
+
"private",
|
|
218
|
+
"protected",
|
|
219
|
+
"global",
|
|
220
|
+
"abstract",
|
|
221
|
+
"virtual",
|
|
222
|
+
"override",
|
|
223
|
+
"with",
|
|
224
|
+
"without",
|
|
225
|
+
"sharing",
|
|
226
|
+
"implements",
|
|
227
|
+
"extends",
|
|
228
|
+
]);
|
|
229
|
+
function isReservedKeyword(s) {
|
|
230
|
+
return RESERVED.has(s.toLowerCase());
|
|
231
|
+
}
|
|
232
|
+
const CONTROL_FLOW = new Set([
|
|
233
|
+
"if",
|
|
234
|
+
"else",
|
|
235
|
+
"for",
|
|
236
|
+
"while",
|
|
237
|
+
"do",
|
|
238
|
+
"switch",
|
|
239
|
+
"return",
|
|
240
|
+
"throw",
|
|
241
|
+
"try",
|
|
242
|
+
"catch",
|
|
243
|
+
"finally",
|
|
244
|
+
"new",
|
|
245
|
+
]);
|
|
246
|
+
function isControlFlowKeyword(s) {
|
|
247
|
+
return CONTROL_FLOW.has(s.toLowerCase());
|
|
248
|
+
}
|
|
249
|
+
const STANDARD_APEX_TYPES = new Set([
|
|
250
|
+
"System",
|
|
251
|
+
"Database",
|
|
252
|
+
"Schema",
|
|
253
|
+
"String",
|
|
254
|
+
"Integer",
|
|
255
|
+
"Decimal",
|
|
256
|
+
"Double",
|
|
257
|
+
"Long",
|
|
258
|
+
"Boolean",
|
|
259
|
+
"Date",
|
|
260
|
+
"Datetime",
|
|
261
|
+
"Time",
|
|
262
|
+
"Id",
|
|
263
|
+
"Object",
|
|
264
|
+
"Blob",
|
|
265
|
+
"List",
|
|
266
|
+
"Set",
|
|
267
|
+
"Map",
|
|
268
|
+
"Test",
|
|
269
|
+
"Limits",
|
|
270
|
+
"UserInfo",
|
|
271
|
+
"Math",
|
|
272
|
+
"Json",
|
|
273
|
+
"JSON",
|
|
274
|
+
"Http",
|
|
275
|
+
"HttpRequest",
|
|
276
|
+
"HttpResponse",
|
|
277
|
+
"Trigger",
|
|
278
|
+
"ApexPages",
|
|
279
|
+
"PageReference",
|
|
280
|
+
"Messaging",
|
|
281
|
+
"Type",
|
|
282
|
+
"DateTime",
|
|
283
|
+
"Pattern",
|
|
284
|
+
"Matcher",
|
|
285
|
+
]);
|
|
286
|
+
function isStandardApexType(s) {
|
|
287
|
+
return STANDARD_APEX_TYPES.has(s);
|
|
288
|
+
}
|
|
289
|
+
//# sourceMappingURL=apex-body.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"apex-body.js","sourceRoot":"","sources":["../../../src/graph/extractors/apex-body.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,5 @@
|
|
|
1
|
+
import type { ApexClass } from "../../types/graph.js";
|
|
2
|
+
import { type ExtractContext } from "./types.js";
|
|
3
|
+
export declare function extractApexClass(ctx: ExtractContext): ApexClass | undefined;
|
|
4
|
+
export declare function readApiVersion(classOrTriggerPath: string, rootElement: "ApexClass" | "ApexTrigger", projectRoot?: string): string;
|
|
5
|
+
//# sourceMappingURL=apex-class.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"apex-class.d.ts","sourceRoot":"","sources":["../../../src/graph/extractors/apex-class.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,sBAAsB,CAAC;AAItD,OAAO,EAAuB,KAAK,cAAc,EAAE,MAAM,YAAY,CAAC;AAEtE,wBAAgB,gBAAgB,CAAC,GAAG,EAAE,cAAc,GAAG,SAAS,GAAG,SAAS,CAqB3E;AAED,wBAAgB,cAAc,CAC5B,kBAAkB,EAAE,MAAM,EAC1B,WAAW,EAAE,WAAW,GAAG,aAAa,EACxC,WAAW,SAAM,GAChB,MAAM,CAaR"}
|
|
@@ -0,0 +1,43 @@
|
|
|
1
|
+
import { existsSync, readFileSync } from "node:fs";
|
|
2
|
+
import { resolve } from "node:path";
|
|
3
|
+
import { asString, parseXml } from "../parse-xml.js";
|
|
4
|
+
import { extractApexBody } from "./apex-body.js";
|
|
5
|
+
import { extractMethodControlFlows } from "./apex-control-flow.js";
|
|
6
|
+
import { DEFAULT_API_VERSION } from "./types.js";
|
|
7
|
+
export function extractApexClass(ctx) {
|
|
8
|
+
const { descriptor, content } = ctx;
|
|
9
|
+
const isMetaXml = descriptor.sourcePath.endsWith("-meta.xml");
|
|
10
|
+
if (isMetaXml)
|
|
11
|
+
return undefined;
|
|
12
|
+
const linesOfCode = content.split("\n").length;
|
|
13
|
+
const isTest = /@isTest\b/i.test(content);
|
|
14
|
+
const apiVersion = readApiVersion(descriptor.sourcePath, "ApexClass", ctx.projectRoot ?? ".");
|
|
15
|
+
const baseBody = extractApexBody(content);
|
|
16
|
+
const controlFlows = extractMethodControlFlows(content);
|
|
17
|
+
const body = { ...baseBody, controlFlows };
|
|
18
|
+
return {
|
|
19
|
+
fullyQualifiedName: descriptor.fullyQualifiedName,
|
|
20
|
+
apiVersion,
|
|
21
|
+
isTest,
|
|
22
|
+
linesOfCode,
|
|
23
|
+
sourcePath: descriptor.sourcePath,
|
|
24
|
+
contentHash: descriptor.contentHash,
|
|
25
|
+
body,
|
|
26
|
+
};
|
|
27
|
+
}
|
|
28
|
+
export function readApiVersion(classOrTriggerPath, rootElement, projectRoot = ".") {
|
|
29
|
+
const metaPath = resolve(projectRoot, `${classOrTriggerPath}-meta.xml`);
|
|
30
|
+
if (!existsSync(metaPath)) {
|
|
31
|
+
return DEFAULT_API_VERSION;
|
|
32
|
+
}
|
|
33
|
+
try {
|
|
34
|
+
const metaContent = readFileSync(metaPath, "utf8");
|
|
35
|
+
const parsed = parseXml(metaContent);
|
|
36
|
+
const root = parsed[rootElement];
|
|
37
|
+
return asString(root?.apiVersion) ?? DEFAULT_API_VERSION;
|
|
38
|
+
}
|
|
39
|
+
catch {
|
|
40
|
+
return DEFAULT_API_VERSION;
|
|
41
|
+
}
|
|
42
|
+
}
|
|
43
|
+
//# sourceMappingURL=apex-class.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"apex-class.js","sourceRoot":"","sources":["../../../src/graph/extractors/apex-class.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAE,YAAY,EAAE,MAAM,SAAS,CAAC;AACnD,OAAO,EAAE,OAAO,EAAE,MAAM,WAAW,CAAC;AAEpC,OAAO,EAAE,QAAQ,EAAE,QAAQ,EAAE,MAAM,iBAAiB,CAAC;AACrD,OAAO,EAAE,eAAe,EAAE,MAAM,gBAAgB,CAAC;AACjD,OAAO,EAAE,yBAAyB,EAAE,MAAM,wBAAwB,CAAC;AACnE,OAAO,EAAE,mBAAmB,EAAuB,MAAM,YAAY,CAAC;AAEtE,MAAM,UAAU,gBAAgB,CAAC,GAAmB;IAClD,MAAM,EAAE,UAAU,EAAE,OAAO,EAAE,GAAG,GAAG,CAAC;IACpC,MAAM,SAAS,GAAG,UAAU,CAAC,UAAU,CAAC,QAAQ,CAAC,WAAW,CAAC,CAAC;IAC9D,IAAI,SAAS;QAAE,OAAO,SAAS,CAAC;IAEhC,MAAM,WAAW,GAAG,OAAO,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC,MAAM,CAAC;IAC/C,MAAM,MAAM,GAAG,YAAY,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;IAC1C,MAAM,UAAU,GAAG,cAAc,CAAC,UAAU,CAAC,UAAU,EAAE,WAAW,EAAE,GAAG,CAAC,WAAW,IAAI,GAAG,CAAC,CAAC;IAC9F,MAAM,QAAQ,GAAG,eAAe,CAAC,OAAO,CAAC,CAAC;IAC1C,MAAM,YAAY,GAAG,yBAAyB,CAAC,OAAO,CAAC,CAAC;IACxD,MAAM,IAAI,GAAG,EAAE,GAAG,QAAQ,EAAE,YAAY,EAAE,CAAC;IAE3C,OAAO;QACL,kBAAkB,EAAE,UAAU,CAAC,kBAAkB;QACjD,UAAU;QACV,MAAM;QACN,WAAW;QACX,UAAU,EAAE,UAAU,CAAC,UAAU;QACjC,WAAW,EAAE,UAAU,CAAC,WAAW;QACnC,IAAI;KACL,CAAC;AACJ,CAAC;AAED,MAAM,UAAU,cAAc,CAC5B,kBAA0B,EAC1B,WAAwC,EACxC,WAAW,GAAG,GAAG;IAEjB,MAAM,QAAQ,GAAG,OAAO,CAAC,WAAW,EAAE,GAAG,kBAAkB,WAAW,CAAC,CAAC;IACxE,IAAI,CAAC,UAAU,CAAC,QAAQ,CAAC,EAAE,CAAC;QAC1B,OAAO,mBAAmB,CAAC;IAC7B,CAAC;IACD,IAAI,CAAC;QACH,MAAM,WAAW,GAAG,YAAY,CAAC,QAAQ,EAAE,MAAM,CAAC,CAAC;QACnD,MAAM,MAAM,GAAG,QAAQ,CAAC,WAAW,CAAC,CAAC;QACrC,MAAM,IAAI,GAAG,MAAM,CAAC,WAAW,CAAwC,CAAC;QACxE,OAAO,QAAQ,CAAC,IAAI,EAAE,UAAU,CAAC,IAAI,mBAAmB,CAAC;IAC3D,CAAC;IAAC,MAAM,CAAC;QACP,OAAO,mBAAmB,CAAC;IAC7B,CAAC;AACH,CAAC"}
|
|
@@ -0,0 +1,33 @@
|
|
|
1
|
+
import type { ApexControlFlowNode, ApexMethodControlFlow } from "../../types/graph.js";
|
|
2
|
+
export type ControlFlowNode = ApexControlFlowNode;
|
|
3
|
+
export type MethodControlFlow = ApexMethodControlFlow;
|
|
4
|
+
export type IfNode = Extract<ApexControlFlowNode, {
|
|
5
|
+
kind: "if";
|
|
6
|
+
}>;
|
|
7
|
+
export type ForNode = Extract<ApexControlFlowNode, {
|
|
8
|
+
kind: "for";
|
|
9
|
+
}>;
|
|
10
|
+
export type WhileNode = Extract<ApexControlFlowNode, {
|
|
11
|
+
kind: "while";
|
|
12
|
+
}>;
|
|
13
|
+
export type TryNode = Extract<ApexControlFlowNode, {
|
|
14
|
+
kind: "try";
|
|
15
|
+
}>;
|
|
16
|
+
export type DmlNode = Extract<ApexControlFlowNode, {
|
|
17
|
+
kind: "dml";
|
|
18
|
+
}>;
|
|
19
|
+
/**
|
|
20
|
+
* クラス全体の中で、各メソッドの { ... } を切り出して制御フロー解析する。
|
|
21
|
+
* 文字列とコメントは事前に除去 (`strip`) してから解析。
|
|
22
|
+
*/
|
|
23
|
+
export declare function extractMethodControlFlows(rawContent: string): readonly MethodControlFlow[];
|
|
24
|
+
/**
|
|
25
|
+
* text[openIdx] が '{' のとき対応する '}' を返す。strip 済前提。
|
|
26
|
+
* 見つからなければ -1。
|
|
27
|
+
*/
|
|
28
|
+
export declare function findMatchingBrace(text: string, openIdx: number): number;
|
|
29
|
+
/**
|
|
30
|
+
* メソッド body や if/else 内の文字列を順序つきの ControlFlowNode 列に変換する。
|
|
31
|
+
*/
|
|
32
|
+
export declare function parseStatements(text: string): readonly ControlFlowNode[];
|
|
33
|
+
//# sourceMappingURL=apex-control-flow.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"apex-control-flow.d.ts","sourceRoot":"","sources":["../../../src/graph/extractors/apex-control-flow.ts"],"names":[],"mappings":"AAwBA,OAAO,KAAK,EAAE,mBAAmB,EAAE,qBAAqB,EAAE,MAAM,sBAAsB,CAAC;AAIvF,MAAM,MAAM,eAAe,GAAG,mBAAmB,CAAC;AAClD,MAAM,MAAM,iBAAiB,GAAG,qBAAqB,CAAC;AACtD,MAAM,MAAM,MAAM,GAAG,OAAO,CAAC,mBAAmB,EAAE;IAAE,IAAI,EAAE,IAAI,CAAA;CAAE,CAAC,CAAC;AAClE,MAAM,MAAM,OAAO,GAAG,OAAO,CAAC,mBAAmB,EAAE;IAAE,IAAI,EAAE,KAAK,CAAA;CAAE,CAAC,CAAC;AACpE,MAAM,MAAM,SAAS,GAAG,OAAO,CAAC,mBAAmB,EAAE;IAAE,IAAI,EAAE,OAAO,CAAA;CAAE,CAAC,CAAC;AACxE,MAAM,MAAM,OAAO,GAAG,OAAO,CAAC,mBAAmB,EAAE;IAAE,IAAI,EAAE,KAAK,CAAA;CAAE,CAAC,CAAC;AACpE,MAAM,MAAM,OAAO,GAAG,OAAO,CAAC,mBAAmB,EAAE;IAAE,IAAI,EAAE,KAAK,CAAA;CAAE,CAAC,CAAC;AAMpE;;;GAGG;AACH,wBAAgB,yBAAyB,CAAC,UAAU,EAAE,MAAM,GAAG,SAAS,iBAAiB,EAAE,CAiC1F;AAoCD;;;GAGG;AACH,wBAAgB,iBAAiB,CAAC,IAAI,EAAE,MAAM,EAAE,OAAO,EAAE,MAAM,GAAG,MAAM,CAYvE;AAmBD;;GAEG;AACH,wBAAgB,eAAe,CAAC,IAAI,EAAE,MAAM,GAAG,SAAS,eAAe,EAAE,CAwBxE"}
|