@su-record/vibe 2.7.17 → 2.7.18

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.
Files changed (245) hide show
  1. package/.env.example +37 -37
  2. package/CLAUDE.md +153 -134
  3. package/LICENSE +21 -21
  4. package/README.md +449 -449
  5. package/agents/architect-low.md +41 -41
  6. package/agents/architect-medium.md +59 -59
  7. package/agents/architect.md +80 -80
  8. package/agents/build-error-resolver.md +115 -115
  9. package/agents/compounder.md +261 -261
  10. package/agents/diagrammer.md +178 -178
  11. package/agents/docs/api-documenter.md +99 -99
  12. package/agents/docs/changelog-writer.md +93 -93
  13. package/agents/e2e-tester.md +294 -294
  14. package/agents/explorer-low.md +42 -42
  15. package/agents/explorer-medium.md +59 -59
  16. package/agents/explorer.md +48 -48
  17. package/agents/implementer-low.md +43 -43
  18. package/agents/implementer-medium.md +52 -52
  19. package/agents/implementer.md +54 -54
  20. package/agents/junior-mentor.md +141 -141
  21. package/agents/planning/requirements-analyst.md +84 -84
  22. package/agents/planning/ux-advisor.md +83 -83
  23. package/agents/qa/acceptance-tester.md +86 -86
  24. package/agents/qa/edge-case-finder.md +93 -93
  25. package/agents/refactor-cleaner.md +143 -143
  26. package/agents/research/best-practices-agent.md +199 -199
  27. package/agents/research/codebase-patterns-agent.md +157 -157
  28. package/agents/research/framework-docs-agent.md +188 -188
  29. package/agents/research/security-advisory-agent.md +213 -213
  30. package/agents/review/architecture-reviewer.md +107 -107
  31. package/agents/review/complexity-reviewer.md +116 -116
  32. package/agents/review/data-integrity-reviewer.md +88 -88
  33. package/agents/review/git-history-reviewer.md +103 -103
  34. package/agents/review/performance-reviewer.md +86 -86
  35. package/agents/review/python-reviewer.md +150 -150
  36. package/agents/review/rails-reviewer.md +139 -139
  37. package/agents/review/react-reviewer.md +144 -144
  38. package/agents/review/security-reviewer.md +80 -80
  39. package/agents/review/simplicity-reviewer.md +140 -140
  40. package/agents/review/test-coverage-reviewer.md +116 -116
  41. package/agents/review/typescript-reviewer.md +127 -127
  42. package/agents/searcher.md +54 -54
  43. package/agents/simplifier.md +120 -120
  44. package/agents/tester.md +49 -49
  45. package/agents/ui/ui-a11y-auditor.md +93 -93
  46. package/agents/ui/ui-antipattern-detector.md +94 -94
  47. package/agents/ui/ui-dataviz-advisor.md +69 -69
  48. package/agents/ui/ui-design-system-gen.md +57 -57
  49. package/agents/ui/ui-industry-analyzer.md +49 -49
  50. package/agents/ui/ui-layout-architect.md +65 -65
  51. package/agents/ui/ui-stack-implementer.md +68 -68
  52. package/agents/ui/ux-compliance-reviewer.md +81 -81
  53. package/agents/ui-previewer.md +258 -258
  54. package/commands/vibe.analyze.md +379 -379
  55. package/commands/vibe.review.md +607 -607
  56. package/commands/vibe.run.md +2124 -2124
  57. package/commands/vibe.spec.md +1195 -1195
  58. package/commands/vibe.spec.review.md +569 -569
  59. package/commands/vibe.utils.md +413 -413
  60. package/commands/vibe.verify.md +484 -484
  61. package/dist/cli/collaborator.js +52 -52
  62. package/dist/cli/commands/evolution.js +12 -12
  63. package/dist/cli/commands/info.js +51 -51
  64. package/dist/cli/commands/init.js +5 -5
  65. package/dist/cli/commands/remove.js +14 -14
  66. package/dist/cli/commands/sentinel.js +27 -27
  67. package/dist/cli/commands/skills.js +5 -5
  68. package/dist/cli/commands/slack.js +10 -10
  69. package/dist/cli/commands/telegram.js +12 -12
  70. package/dist/cli/detect.js +32 -32
  71. package/dist/cli/index.js +51 -51
  72. package/dist/cli/llm/claude-commands.js +16 -16
  73. package/dist/cli/llm/config.js +18 -18
  74. package/dist/cli/llm/gemini-commands.js +16 -16
  75. package/dist/cli/llm/gpt-commands.js +19 -19
  76. package/dist/cli/llm/help.js +21 -21
  77. package/dist/cli/postinstall/cursor-agents.js +32 -32
  78. package/dist/cli/postinstall/cursor-rules.js +83 -83
  79. package/dist/cli/postinstall/cursor-skills.js +743 -743
  80. package/dist/cli/setup/Provisioner.js +42 -42
  81. package/dist/infra/lib/DeepInit.js +24 -24
  82. package/dist/infra/lib/IterationTracker.js +11 -11
  83. package/dist/infra/lib/PythonParser.js +108 -108
  84. package/dist/infra/lib/ReviewRace.js +96 -96
  85. package/dist/infra/lib/SkillFrontmatter.js +28 -28
  86. package/dist/infra/lib/SkillQualityGate.js +9 -9
  87. package/dist/infra/lib/SkillRepository.js +159 -159
  88. package/dist/infra/lib/UltraQA.js +99 -99
  89. package/dist/infra/lib/autonomy/AuditStore.js +41 -41
  90. package/dist/infra/lib/autonomy/ConfirmationStore.js +30 -30
  91. package/dist/infra/lib/autonomy/EventOutbox.js +38 -38
  92. package/dist/infra/lib/autonomy/PolicyEngine.js +18 -18
  93. package/dist/infra/lib/autonomy/SecuritySentinel.js +1 -1
  94. package/dist/infra/lib/autonomy/SuggestionStore.js +33 -33
  95. package/dist/infra/lib/embedding/VectorStore.js +22 -22
  96. package/dist/infra/lib/evolution/AgentAnalyzer.js +10 -10
  97. package/dist/infra/lib/evolution/DescriptionOptimizer.js +21 -21
  98. package/dist/infra/lib/evolution/GenerationRegistry.js +36 -36
  99. package/dist/infra/lib/evolution/InsightStore.js +90 -90
  100. package/dist/infra/lib/evolution/RollbackManager.js +5 -5
  101. package/dist/infra/lib/evolution/SkillBenchmark.js +23 -23
  102. package/dist/infra/lib/evolution/SkillEvalRunner.js +50 -50
  103. package/dist/infra/lib/evolution/SkillGapDetector.js +10 -10
  104. package/dist/infra/lib/evolution/UsageTracker.js +28 -28
  105. package/dist/infra/lib/gemini/orchestration.js +5 -5
  106. package/dist/infra/lib/gpt/orchestration.js +4 -4
  107. package/dist/infra/lib/memory/KnowledgeGraph.js +4 -4
  108. package/dist/infra/lib/memory/MemorySearch.js +57 -57
  109. package/dist/infra/lib/memory/MemoryStorage.js +181 -181
  110. package/dist/infra/lib/memory/ObservationStore.js +28 -28
  111. package/dist/infra/lib/memory/ReflectionStore.js +30 -30
  112. package/dist/infra/lib/memory/SessionRAGRetriever.js +7 -7
  113. package/dist/infra/lib/memory/SessionRAGStore.js +225 -225
  114. package/dist/infra/lib/memory/SessionSummarizer.js +9 -9
  115. package/dist/infra/lib/telemetry/SkillTelemetry.d.ts +52 -0
  116. package/dist/infra/lib/telemetry/SkillTelemetry.d.ts.map +1 -0
  117. package/dist/infra/lib/telemetry/SkillTelemetry.js +117 -0
  118. package/dist/infra/lib/telemetry/SkillTelemetry.js.map +1 -0
  119. package/dist/infra/lib/telemetry/SkillTelemetry.test.d.ts +2 -0
  120. package/dist/infra/lib/telemetry/SkillTelemetry.test.d.ts.map +1 -0
  121. package/dist/infra/lib/telemetry/SkillTelemetry.test.js +91 -0
  122. package/dist/infra/lib/telemetry/SkillTelemetry.test.js.map +1 -0
  123. package/dist/infra/orchestrator/AgentManager.js +12 -12
  124. package/dist/infra/orchestrator/AgentRegistry.js +65 -65
  125. package/dist/infra/orchestrator/MultiLlmResearch.js +8 -8
  126. package/dist/infra/orchestrator/SwarmOrchestrator.test.js +16 -16
  127. package/dist/infra/orchestrator/parallelResearch.js +24 -24
  128. package/dist/test-helpers/index.d.ts +36 -0
  129. package/dist/test-helpers/index.d.ts.map +1 -0
  130. package/dist/test-helpers/index.js +85 -0
  131. package/dist/test-helpers/index.js.map +1 -0
  132. package/dist/test-helpers/index.test.d.ts +2 -0
  133. package/dist/test-helpers/index.test.d.ts.map +1 -0
  134. package/dist/test-helpers/index.test.js +92 -0
  135. package/dist/test-helpers/index.test.js.map +1 -0
  136. package/dist/tools/convention/analyzeComplexity.test.js +115 -115
  137. package/dist/tools/convention/validateCodeQuality.test.js +104 -104
  138. package/dist/tools/memory/createMemoryTimeline.js +10 -10
  139. package/dist/tools/memory/getMemoryGraph.js +12 -12
  140. package/dist/tools/memory/getSessionContext.js +9 -9
  141. package/dist/tools/memory/linkMemories.js +14 -14
  142. package/dist/tools/memory/listMemories.js +4 -4
  143. package/dist/tools/memory/recallMemory.js +4 -4
  144. package/dist/tools/memory/saveMemory.js +4 -4
  145. package/dist/tools/memory/searchMemoriesAdvanced.js +23 -23
  146. package/dist/tools/semantic/analyzeDependencyGraph.js +12 -12
  147. package/dist/tools/semantic/astGrep.test.js +6 -6
  148. package/dist/tools/spec/prdParser.test.js +171 -171
  149. package/dist/tools/spec/specGenerator.js +169 -169
  150. package/dist/tools/spec/traceabilityMatrix.js +64 -64
  151. package/dist/tools/spec/traceabilityMatrix.test.js +28 -28
  152. package/hooks/gemini-hooks.json +73 -73
  153. package/hooks/hooks.json +137 -137
  154. package/hooks/scripts/code-check.js +77 -77
  155. package/hooks/scripts/context-save.js +212 -212
  156. package/hooks/scripts/hud-status.js +291 -291
  157. package/hooks/scripts/keyword-detector.js +214 -214
  158. package/hooks/scripts/llm-orchestrate.js +475 -475
  159. package/hooks/scripts/post-edit.js +32 -32
  160. package/hooks/scripts/pre-tool-guard.js +125 -125
  161. package/hooks/scripts/prompt-dispatcher.js +185 -185
  162. package/hooks/scripts/sentinel-guard.js +104 -104
  163. package/hooks/scripts/session-start.js +106 -106
  164. package/hooks/scripts/stop-notify.js +209 -209
  165. package/hooks/scripts/utils.js +100 -100
  166. package/languages/csharp-unity.md +515 -515
  167. package/languages/gdscript-godot.md +470 -470
  168. package/languages/ruby-rails.md +489 -489
  169. package/languages/typescript-angular.md +433 -433
  170. package/languages/typescript-astro.md +416 -416
  171. package/languages/typescript-electron.md +406 -406
  172. package/languages/typescript-nestjs.md +524 -524
  173. package/languages/typescript-svelte.md +407 -407
  174. package/languages/typescript-tauri.md +365 -365
  175. package/package.json +123 -121
  176. package/skills/agents-md/SKILL.md +120 -120
  177. package/skills/arch-guard/SKILL.md +180 -180
  178. package/skills/brand-assets/SKILL.md +146 -146
  179. package/skills/capability-loop/SKILL.md +167 -167
  180. package/skills/characterization-test/SKILL.md +206 -206
  181. package/skills/commerce-patterns/SKILL.md +63 -63
  182. package/skills/commit-push-pr/SKILL.md +75 -75
  183. package/skills/context7-usage/SKILL.md +105 -105
  184. package/skills/core-capabilities/SKILL.md +13 -13
  185. package/skills/e2e-commerce/SKILL.md +61 -61
  186. package/skills/exec-plan/SKILL.md +147 -147
  187. package/skills/frontend-design/SKILL.md +12 -12
  188. package/skills/git-worktree/SKILL.md +72 -72
  189. package/skills/handoff/SKILL.md +109 -109
  190. package/skills/parallel-research/SKILL.md +87 -87
  191. package/skills/priority-todos/SKILL.md +63 -63
  192. package/skills/seo-checklist/SKILL.md +57 -57
  193. package/skills/techdebt/SKILL.md +122 -122
  194. package/skills/tool-fallback/SKILL.md +103 -103
  195. package/skills/typescript-advanced-types/SKILL.md +66 -66
  196. package/skills/ui-ux-pro-max/SKILL.md +221 -221
  197. package/skills/vercel-react-best-practices/SKILL.md +59 -59
  198. package/skills/video-production/SKILL.md +51 -51
  199. package/vibe/config.json +29 -29
  200. package/vibe/constitution.md +227 -227
  201. package/vibe/rules/principles/communication-guide.md +98 -98
  202. package/vibe/rules/principles/development-philosophy.md +52 -52
  203. package/vibe/rules/principles/quick-start.md +102 -102
  204. package/vibe/rules/quality/bdd-contract-testing.md +393 -393
  205. package/vibe/rules/quality/checklist.md +276 -276
  206. package/vibe/rules/quality/performance.md +236 -236
  207. package/vibe/rules/quality/testing-strategy.md +440 -440
  208. package/vibe/rules/standards/anti-patterns.md +541 -541
  209. package/vibe/rules/standards/code-structure.md +291 -291
  210. package/vibe/rules/standards/complexity-metrics.md +313 -313
  211. package/vibe/rules/standards/git-workflow.md +237 -237
  212. package/vibe/rules/standards/naming-conventions.md +198 -198
  213. package/vibe/rules/standards/security.md +305 -305
  214. package/vibe/rules/writing/document-style.md +74 -74
  215. package/vibe/setup.sh +31 -31
  216. package/vibe/templates/constitution-template.md +252 -252
  217. package/vibe/templates/contract-backend-template.md +526 -526
  218. package/vibe/templates/contract-frontend-template.md +599 -599
  219. package/vibe/templates/feature-template.md +96 -96
  220. package/vibe/templates/spec-template.md +221 -221
  221. package/vibe/ui-ux-data/charts.csv +26 -26
  222. package/vibe/ui-ux-data/colors.csv +97 -97
  223. package/vibe/ui-ux-data/icons.csv +101 -101
  224. package/vibe/ui-ux-data/landing.csv +31 -31
  225. package/vibe/ui-ux-data/products.csv +96 -96
  226. package/vibe/ui-ux-data/react-performance.csv +45 -45
  227. package/vibe/ui-ux-data/stacks/astro.csv +54 -54
  228. package/vibe/ui-ux-data/stacks/flutter.csv +53 -53
  229. package/vibe/ui-ux-data/stacks/html-tailwind.csv +56 -56
  230. package/vibe/ui-ux-data/stacks/jetpack-compose.csv +53 -53
  231. package/vibe/ui-ux-data/stacks/nextjs.csv +53 -53
  232. package/vibe/ui-ux-data/stacks/nuxt-ui.csv +51 -51
  233. package/vibe/ui-ux-data/stacks/nuxtjs.csv +59 -59
  234. package/vibe/ui-ux-data/stacks/react-native.csv +52 -52
  235. package/vibe/ui-ux-data/stacks/react.csv +54 -54
  236. package/vibe/ui-ux-data/stacks/shadcn.csv +61 -61
  237. package/vibe/ui-ux-data/stacks/svelte.csv +54 -54
  238. package/vibe/ui-ux-data/stacks/swiftui.csv +51 -51
  239. package/vibe/ui-ux-data/stacks/vue.csv +50 -50
  240. package/vibe/ui-ux-data/styles.csv +68 -68
  241. package/vibe/ui-ux-data/typography.csv +57 -57
  242. package/vibe/ui-ux-data/ui-reasoning.csv +101 -101
  243. package/vibe/ui-ux-data/ux-guidelines.csv +99 -99
  244. package/vibe/ui-ux-data/version.json +31 -31
  245. package/vibe/ui-ux-data/web-interface.csv +31 -31
@@ -1,313 +1,313 @@
1
- # Software Engineering Complexity Measurement
2
-
3
- ## 4.1 Complexity Metrics
4
-
5
- ### Cyclomatic Complexity
6
-
7
- **Definition**: Number of independent execution paths in code
8
-
9
- **Target**: ≤ 10
10
-
11
- ```typescript
12
- // ❌ High cyclomatic complexity (6)
13
- function processUser(user) {
14
- if (user.isActive) { // +1
15
- if (user.hasPermission) { // +1
16
- if (user.email) { // +1
17
- if (user.verified) { // +1
18
- return processData();
19
- }
20
- }
21
- }
22
- }
23
- return null;
24
- }
25
-
26
- // ✅ Low cyclomatic complexity (4) - Using early returns
27
- function processUser(user) {
28
- if (!user.isActive) return null; // +1
29
- if (!user.hasPermission) return null; // +1
30
- if (!user.email) return null; // +1
31
- if (!user.verified) return null; // +1
32
-
33
- return processData();
34
- }
35
- ```
36
-
37
- ### Cognitive Complexity
38
-
39
- **Definition**: Mental effort required to understand code
40
-
41
- **Target**: ≤ 15
42
-
43
- ```typescript
44
- // ❌ High cognitive complexity
45
- function calculateDiscount(user, items) {
46
- let discount = 0;
47
- if (user.isPremium) { // +1
48
- for (let item of items) { // +1 (nesting)
49
- if (item.category === 'electronics') { // +2 (nested if)
50
- discount += item.price * 0.1;
51
- } else if (item.category === 'books') { // +1
52
- discount += item.price * 0.05;
53
- }
54
- }
55
- }
56
- return discount;
57
- }
58
-
59
- // ✅ Low cognitive complexity - Function separation
60
- function calculateDiscount(user, items) {
61
- if (!user.isPremium) return 0; // +1
62
- return items.reduce((total, item) => total + getItemDiscount(item), 0);
63
- }
64
-
65
- function getItemDiscount(item) {
66
- const discountRates = {
67
- electronics: 0.1,
68
- books: 0.05,
69
- };
70
- return item.price * (discountRates[item.category] || 0);
71
- }
72
- ```
73
-
74
- ### Halstead Metrics
75
-
76
- **Measurements**:
77
-
78
- - **Operators**: Operators (=, +, -, *, if, for, etc.)
79
- - **Operands**: Operands (variables, constants, function names)
80
- - **Vocabulary**: Unique operators + unique operands
81
- - **Length**: Total token count
82
- - **Difficulty**: Code comprehension difficulty
83
- - **Effort**: Mental effort required to write code
84
-
85
- ```typescript
86
- // Halstead metrics measurement example
87
- function calculateArea(radius: number): number {
88
- const pi = 3.14159;
89
- return pi * radius * radius;
90
- }
91
-
92
- /*
93
- Operators: =, *, const, function, :, return (6)
94
- Operands: calculateArea, radius, number, pi, 3.14159 (5)
95
- Vocabulary: 6 + 5 = 11
96
- Length: Total token count
97
- Difficulty: Calculated from Vocabulary and operand repetition
98
- Effort: Difficulty × Volume
99
- */
100
- ```
101
-
102
- ## 4.2 Coupling & Cohesion
103
-
104
- ### Loose Coupling
105
-
106
- **Goal**: Minimize dependencies between modules
107
-
108
- ```typescript
109
- // ❌ Tight coupling - Direct dependencies
110
- class UserService {
111
- constructor() {
112
- this.database = new PostgreSQLDatabase(); // Direct dependency
113
- this.emailService = new SendGridEmail(); // Direct dependency
114
- }
115
- }
116
-
117
- // ✅ Loose coupling - Dependency injection
118
- interface IDatabase {
119
- save(data: unknown): Promise<void>;
120
- load(id: string): Promise<unknown>;
121
- }
122
-
123
- interface IEmailService {
124
- send(to: string, message: string): Promise<void>;
125
- }
126
-
127
- class UserService {
128
- constructor(
129
- private database: IDatabase,
130
- private emailService: IEmailService
131
- ) {}
132
- }
133
-
134
- // Usage
135
- const userService = new UserService(
136
- new PostgreSQLDatabase(),
137
- new SendGridEmail()
138
- );
139
- ```
140
-
141
- ### High Cohesion
142
-
143
- **Goal**: Group only related functions together
144
-
145
- ```typescript
146
- // ❌ Low cohesion - Unrelated functions
147
- class Utils {
148
- validateEmail(email: string) { /* */ }
149
- formatCurrency(amount: number) { /* */ }
150
- sendNotification(message: string) { /* */ }
151
- calculateTax(income: number) { /* */ }
152
- }
153
-
154
- // ✅ High cohesion - Only related functions
155
- class EmailValidator {
156
- validateFormat(email: string) { /* */ }
157
- validateDomain(email: string) { /* */ }
158
- validateMX(email: string) { /* */ }
159
- }
160
-
161
- class CurrencyFormatter {
162
- formatKRW(amount: number) { /* */ }
163
- formatUSD(amount: number) { /* */ }
164
- parseAmount(formatted: string) { /* */ }
165
- }
166
-
167
- class TaxCalculator {
168
- calculateIncomeTax(income: number) { /* */ }
169
- calculateVAT(amount: number) { /* */ }
170
- calculateTotal(income: number) { /* */ }
171
- }
172
- ```
173
-
174
- ## Complexity Reduction Strategies
175
-
176
- ### 1. Early Return Pattern
177
-
178
- ```typescript
179
- // ❌ Nested if statements
180
- function processOrder(order: Order) {
181
- if (order) {
182
- if (order.isValid) {
183
- if (order.items.length > 0) {
184
- if (order.user.isActive) {
185
- return processItems(order.items);
186
- }
187
- }
188
- }
189
- }
190
- return null;
191
- }
192
-
193
- // ✅ Early return
194
- function processOrder(order: Order) {
195
- if (!order) return null;
196
- if (!order.isValid) return null;
197
- if (order.items.length === 0) return null;
198
- if (!order.user.isActive) return null;
199
-
200
- return processItems(order.items);
201
- }
202
- ```
203
-
204
- ### 2. Strategy Pattern
205
-
206
- ```typescript
207
- // ❌ Complex if-else chain
208
- function calculateShipping(type: string, weight: number) {
209
- if (type === 'express') {
210
- return weight * 5 + 10;
211
- } else if (type === 'standard') {
212
- return weight * 3 + 5;
213
- } else if (type === 'economy') {
214
- return weight * 2;
215
- }
216
- return 0;
217
- }
218
-
219
- // ✅ Strategy pattern
220
- interface ShippingStrategy {
221
- calculate(weight: number): number;
222
- }
223
-
224
- class ExpressShipping implements ShippingStrategy {
225
- calculate(weight: number) {
226
- return weight * 5 + 10;
227
- }
228
- }
229
-
230
- class StandardShipping implements ShippingStrategy {
231
- calculate(weight: number) {
232
- return weight * 3 + 5;
233
- }
234
- }
235
-
236
- const strategies: Record<string, ShippingStrategy> = {
237
- express: new ExpressShipping(),
238
- standard: new StandardShipping(),
239
- };
240
-
241
- function calculateShipping(type: string, weight: number) {
242
- const strategy = strategies[type];
243
- return strategy ? strategy.calculate(weight) : 0;
244
- }
245
- ```
246
-
247
- ### 3. Extract Function
248
-
249
- ```typescript
250
- // ❌ Long function
251
- function processUserRegistration(userData: UserData) {
252
- // 20 lines: Email validation
253
- // 15 lines: Password hashing
254
- // 10 lines: Database save
255
- // 5 lines: Welcome email
256
- }
257
-
258
- // ✅ Extract functions
259
- function processUserRegistration(userData: UserData) {
260
- validateEmail(userData.email);
261
- const hashedPassword = hashPassword(userData.password);
262
- const user = saveToDatabase({ ...userData, password: hashedPassword });
263
- sendWelcomeEmail(user.email);
264
- return user;
265
- }
266
-
267
- function validateEmail(email: string) { /* ... */ }
268
- function hashPassword(password: string) { /* ... */ }
269
- function saveToDatabase(data: UserData) { /* ... */ }
270
- function sendWelcomeEmail(email: string) { /* ... */ }
271
- ```
272
-
273
- ## Measurement Tools
274
-
275
- ### TypeScript/JavaScript
276
-
277
- ```bash
278
- # ESLint (complexity measurement plugin)
279
- npm install eslint-plugin-complexity
280
-
281
- # .eslintrc.js
282
- {
283
- "rules": {
284
- "complexity": ["error", 10],
285
- "max-depth": ["error", 3],
286
- "max-lines-per-function": ["error", 20]
287
- }
288
- }
289
- ```
290
-
291
- ### Python
292
-
293
- ```bash
294
- # Radon (complexity measurement tool)
295
- pip install radon
296
-
297
- # Cyclomatic Complexity
298
- radon cc app/ -a -nc
299
-
300
- # Maintainability Index
301
- radon mi app/
302
- ```
303
-
304
- ## Target Metrics Summary
305
-
306
- | Metric | Target | Description |
307
- |--------|--------|-------------|
308
- | Cyclomatic Complexity | ≤ 10 | Independent execution paths |
309
- | Cognitive Complexity | ≤ 15 | Easy to understand |
310
- | Function Length | ≤ 20 lines | Short, focused functions |
311
- | Nesting Depth | ≤ 3 levels | Flat structure |
312
- | Parameters | ≤ 5 | Function parameter limit |
313
- | Dependencies | ≤ 7 | Module dependency limit |
1
+ # Software Engineering Complexity Measurement
2
+
3
+ ## 4.1 Complexity Metrics
4
+
5
+ ### Cyclomatic Complexity
6
+
7
+ **Definition**: Number of independent execution paths in code
8
+
9
+ **Target**: ≤ 10
10
+
11
+ ```typescript
12
+ // ❌ High cyclomatic complexity (6)
13
+ function processUser(user) {
14
+ if (user.isActive) { // +1
15
+ if (user.hasPermission) { // +1
16
+ if (user.email) { // +1
17
+ if (user.verified) { // +1
18
+ return processData();
19
+ }
20
+ }
21
+ }
22
+ }
23
+ return null;
24
+ }
25
+
26
+ // ✅ Low cyclomatic complexity (4) - Using early returns
27
+ function processUser(user) {
28
+ if (!user.isActive) return null; // +1
29
+ if (!user.hasPermission) return null; // +1
30
+ if (!user.email) return null; // +1
31
+ if (!user.verified) return null; // +1
32
+
33
+ return processData();
34
+ }
35
+ ```
36
+
37
+ ### Cognitive Complexity
38
+
39
+ **Definition**: Mental effort required to understand code
40
+
41
+ **Target**: ≤ 15
42
+
43
+ ```typescript
44
+ // ❌ High cognitive complexity
45
+ function calculateDiscount(user, items) {
46
+ let discount = 0;
47
+ if (user.isPremium) { // +1
48
+ for (let item of items) { // +1 (nesting)
49
+ if (item.category === 'electronics') { // +2 (nested if)
50
+ discount += item.price * 0.1;
51
+ } else if (item.category === 'books') { // +1
52
+ discount += item.price * 0.05;
53
+ }
54
+ }
55
+ }
56
+ return discount;
57
+ }
58
+
59
+ // ✅ Low cognitive complexity - Function separation
60
+ function calculateDiscount(user, items) {
61
+ if (!user.isPremium) return 0; // +1
62
+ return items.reduce((total, item) => total + getItemDiscount(item), 0);
63
+ }
64
+
65
+ function getItemDiscount(item) {
66
+ const discountRates = {
67
+ electronics: 0.1,
68
+ books: 0.05,
69
+ };
70
+ return item.price * (discountRates[item.category] || 0);
71
+ }
72
+ ```
73
+
74
+ ### Halstead Metrics
75
+
76
+ **Measurements**:
77
+
78
+ - **Operators**: Operators (=, +, -, *, if, for, etc.)
79
+ - **Operands**: Operands (variables, constants, function names)
80
+ - **Vocabulary**: Unique operators + unique operands
81
+ - **Length**: Total token count
82
+ - **Difficulty**: Code comprehension difficulty
83
+ - **Effort**: Mental effort required to write code
84
+
85
+ ```typescript
86
+ // Halstead metrics measurement example
87
+ function calculateArea(radius: number): number {
88
+ const pi = 3.14159;
89
+ return pi * radius * radius;
90
+ }
91
+
92
+ /*
93
+ Operators: =, *, const, function, :, return (6)
94
+ Operands: calculateArea, radius, number, pi, 3.14159 (5)
95
+ Vocabulary: 6 + 5 = 11
96
+ Length: Total token count
97
+ Difficulty: Calculated from Vocabulary and operand repetition
98
+ Effort: Difficulty × Volume
99
+ */
100
+ ```
101
+
102
+ ## 4.2 Coupling & Cohesion
103
+
104
+ ### Loose Coupling
105
+
106
+ **Goal**: Minimize dependencies between modules
107
+
108
+ ```typescript
109
+ // ❌ Tight coupling - Direct dependencies
110
+ class UserService {
111
+ constructor() {
112
+ this.database = new PostgreSQLDatabase(); // Direct dependency
113
+ this.emailService = new SendGridEmail(); // Direct dependency
114
+ }
115
+ }
116
+
117
+ // ✅ Loose coupling - Dependency injection
118
+ interface IDatabase {
119
+ save(data: unknown): Promise<void>;
120
+ load(id: string): Promise<unknown>;
121
+ }
122
+
123
+ interface IEmailService {
124
+ send(to: string, message: string): Promise<void>;
125
+ }
126
+
127
+ class UserService {
128
+ constructor(
129
+ private database: IDatabase,
130
+ private emailService: IEmailService
131
+ ) {}
132
+ }
133
+
134
+ // Usage
135
+ const userService = new UserService(
136
+ new PostgreSQLDatabase(),
137
+ new SendGridEmail()
138
+ );
139
+ ```
140
+
141
+ ### High Cohesion
142
+
143
+ **Goal**: Group only related functions together
144
+
145
+ ```typescript
146
+ // ❌ Low cohesion - Unrelated functions
147
+ class Utils {
148
+ validateEmail(email: string) { /* */ }
149
+ formatCurrency(amount: number) { /* */ }
150
+ sendNotification(message: string) { /* */ }
151
+ calculateTax(income: number) { /* */ }
152
+ }
153
+
154
+ // ✅ High cohesion - Only related functions
155
+ class EmailValidator {
156
+ validateFormat(email: string) { /* */ }
157
+ validateDomain(email: string) { /* */ }
158
+ validateMX(email: string) { /* */ }
159
+ }
160
+
161
+ class CurrencyFormatter {
162
+ formatKRW(amount: number) { /* */ }
163
+ formatUSD(amount: number) { /* */ }
164
+ parseAmount(formatted: string) { /* */ }
165
+ }
166
+
167
+ class TaxCalculator {
168
+ calculateIncomeTax(income: number) { /* */ }
169
+ calculateVAT(amount: number) { /* */ }
170
+ calculateTotal(income: number) { /* */ }
171
+ }
172
+ ```
173
+
174
+ ## Complexity Reduction Strategies
175
+
176
+ ### 1. Early Return Pattern
177
+
178
+ ```typescript
179
+ // ❌ Nested if statements
180
+ function processOrder(order: Order) {
181
+ if (order) {
182
+ if (order.isValid) {
183
+ if (order.items.length > 0) {
184
+ if (order.user.isActive) {
185
+ return processItems(order.items);
186
+ }
187
+ }
188
+ }
189
+ }
190
+ return null;
191
+ }
192
+
193
+ // ✅ Early return
194
+ function processOrder(order: Order) {
195
+ if (!order) return null;
196
+ if (!order.isValid) return null;
197
+ if (order.items.length === 0) return null;
198
+ if (!order.user.isActive) return null;
199
+
200
+ return processItems(order.items);
201
+ }
202
+ ```
203
+
204
+ ### 2. Strategy Pattern
205
+
206
+ ```typescript
207
+ // ❌ Complex if-else chain
208
+ function calculateShipping(type: string, weight: number) {
209
+ if (type === 'express') {
210
+ return weight * 5 + 10;
211
+ } else if (type === 'standard') {
212
+ return weight * 3 + 5;
213
+ } else if (type === 'economy') {
214
+ return weight * 2;
215
+ }
216
+ return 0;
217
+ }
218
+
219
+ // ✅ Strategy pattern
220
+ interface ShippingStrategy {
221
+ calculate(weight: number): number;
222
+ }
223
+
224
+ class ExpressShipping implements ShippingStrategy {
225
+ calculate(weight: number) {
226
+ return weight * 5 + 10;
227
+ }
228
+ }
229
+
230
+ class StandardShipping implements ShippingStrategy {
231
+ calculate(weight: number) {
232
+ return weight * 3 + 5;
233
+ }
234
+ }
235
+
236
+ const strategies: Record<string, ShippingStrategy> = {
237
+ express: new ExpressShipping(),
238
+ standard: new StandardShipping(),
239
+ };
240
+
241
+ function calculateShipping(type: string, weight: number) {
242
+ const strategy = strategies[type];
243
+ return strategy ? strategy.calculate(weight) : 0;
244
+ }
245
+ ```
246
+
247
+ ### 3. Extract Function
248
+
249
+ ```typescript
250
+ // ❌ Long function
251
+ function processUserRegistration(userData: UserData) {
252
+ // 20 lines: Email validation
253
+ // 15 lines: Password hashing
254
+ // 10 lines: Database save
255
+ // 5 lines: Welcome email
256
+ }
257
+
258
+ // ✅ Extract functions
259
+ function processUserRegistration(userData: UserData) {
260
+ validateEmail(userData.email);
261
+ const hashedPassword = hashPassword(userData.password);
262
+ const user = saveToDatabase({ ...userData, password: hashedPassword });
263
+ sendWelcomeEmail(user.email);
264
+ return user;
265
+ }
266
+
267
+ function validateEmail(email: string) { /* ... */ }
268
+ function hashPassword(password: string) { /* ... */ }
269
+ function saveToDatabase(data: UserData) { /* ... */ }
270
+ function sendWelcomeEmail(email: string) { /* ... */ }
271
+ ```
272
+
273
+ ## Measurement Tools
274
+
275
+ ### TypeScript/JavaScript
276
+
277
+ ```bash
278
+ # ESLint (complexity measurement plugin)
279
+ npm install eslint-plugin-complexity
280
+
281
+ # .eslintrc.js
282
+ {
283
+ "rules": {
284
+ "complexity": ["error", 10],
285
+ "max-depth": ["error", 3],
286
+ "max-lines-per-function": ["error", 20]
287
+ }
288
+ }
289
+ ```
290
+
291
+ ### Python
292
+
293
+ ```bash
294
+ # Radon (complexity measurement tool)
295
+ pip install radon
296
+
297
+ # Cyclomatic Complexity
298
+ radon cc app/ -a -nc
299
+
300
+ # Maintainability Index
301
+ radon mi app/
302
+ ```
303
+
304
+ ## Target Metrics Summary
305
+
306
+ | Metric | Target | Description |
307
+ |--------|--------|-------------|
308
+ | Cyclomatic Complexity | ≤ 10 | Independent execution paths |
309
+ | Cognitive Complexity | ≤ 15 | Easy to understand |
310
+ | Function Length | ≤ 20 lines | Short, focused functions |
311
+ | Nesting Depth | ≤ 3 levels | Flat structure |
312
+ | Parameters | ≤ 5 | Function parameter limit |
313
+ | Dependencies | ≤ 7 | Module dependency limit |