@su-record/vibe 2.6.16 → 2.6.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 (249) hide show
  1. package/CLAUDE.md +681 -681
  2. package/LICENSE +21 -21
  3. package/README.md +235 -203
  4. package/agents/architect-low.md +41 -41
  5. package/agents/architect-medium.md +59 -59
  6. package/agents/architect.md +80 -80
  7. package/agents/build-error-resolver.md +115 -115
  8. package/agents/compounder.md +261 -261
  9. package/agents/diagrammer.md +178 -178
  10. package/agents/e2e-tester.md +266 -266
  11. package/agents/explorer-low.md +42 -42
  12. package/agents/explorer-medium.md +59 -59
  13. package/agents/explorer.md +48 -48
  14. package/agents/implementer-low.md +43 -43
  15. package/agents/implementer-medium.md +52 -52
  16. package/agents/implementer.md +54 -54
  17. package/agents/refactor-cleaner.md +143 -143
  18. package/agents/research/best-practices-agent.md +199 -199
  19. package/agents/research/codebase-patterns-agent.md +157 -157
  20. package/agents/research/framework-docs-agent.md +188 -188
  21. package/agents/research/security-advisory-agent.md +213 -213
  22. package/agents/review/architecture-reviewer.md +107 -107
  23. package/agents/review/complexity-reviewer.md +116 -116
  24. package/agents/review/data-integrity-reviewer.md +88 -88
  25. package/agents/review/git-history-reviewer.md +103 -103
  26. package/agents/review/performance-reviewer.md +86 -86
  27. package/agents/review/python-reviewer.md +150 -150
  28. package/agents/review/rails-reviewer.md +139 -139
  29. package/agents/review/react-reviewer.md +144 -144
  30. package/agents/review/security-reviewer.md +80 -80
  31. package/agents/review/simplicity-reviewer.md +140 -140
  32. package/agents/review/test-coverage-reviewer.md +116 -116
  33. package/agents/review/typescript-reviewer.md +127 -127
  34. package/agents/searcher.md +54 -54
  35. package/agents/simplifier.md +120 -120
  36. package/agents/tester.md +49 -49
  37. package/agents/ui-previewer.md +268 -268
  38. package/commands/vibe.analyze.md +356 -356
  39. package/commands/vibe.reason.md +329 -329
  40. package/commands/vibe.review.md +412 -412
  41. package/commands/vibe.run.md +1266 -1266
  42. package/commands/vibe.spec.md +1054 -1054
  43. package/commands/vibe.spec.review.md +319 -319
  44. package/commands/vibe.trace.md +161 -161
  45. package/commands/vibe.utils.md +376 -376
  46. package/commands/vibe.verify.md +375 -375
  47. package/dist/cli/collaborator.js +52 -52
  48. package/dist/cli/detect.js +32 -32
  49. package/dist/cli/hud.js +20 -20
  50. package/dist/cli/index.d.ts.map +1 -1
  51. package/dist/cli/index.js +120 -118
  52. package/dist/cli/index.js.map +1 -1
  53. package/dist/cli/llm.js +144 -144
  54. package/dist/cli/postinstall.d.ts +1 -0
  55. package/dist/cli/postinstall.d.ts.map +1 -1
  56. package/dist/cli/postinstall.js +859 -859
  57. package/dist/cli/postinstall.js.map +1 -1
  58. package/dist/cli/setup/ProjectSetup.d.ts +2 -2
  59. package/dist/cli/setup/ProjectSetup.d.ts.map +1 -1
  60. package/dist/cli/setup/ProjectSetup.js +51 -17
  61. package/dist/cli/setup/ProjectSetup.js.map +1 -1
  62. package/dist/lib/DeepInit.js +24 -24
  63. package/dist/lib/IterationTracker.js +11 -11
  64. package/dist/lib/PythonParser.js +108 -108
  65. package/dist/lib/ReviewRace.js +96 -96
  66. package/dist/lib/SkillFrontmatter.js +28 -28
  67. package/dist/lib/SkillQualityGate.js +9 -9
  68. package/dist/lib/SkillRepository.js +159 -159
  69. package/dist/lib/UltraQA.js +77 -77
  70. package/dist/lib/gemini-api.js +5 -5
  71. package/dist/lib/gpt-api.js +4 -4
  72. package/dist/lib/memory/KnowledgeGraph.js +4 -4
  73. package/dist/lib/memory/MemorySearch.js +20 -20
  74. package/dist/lib/memory/MemoryStorage.js +64 -64
  75. package/dist/orchestrator/AgentManager.js +12 -12
  76. package/dist/orchestrator/MultiLlmResearch.js +8 -8
  77. package/dist/orchestrator/SmartRouter.js +11 -11
  78. package/dist/orchestrator/SwarmOrchestrator.d.ts +144 -0
  79. package/dist/orchestrator/SwarmOrchestrator.d.ts.map +1 -0
  80. package/dist/orchestrator/SwarmOrchestrator.js +361 -0
  81. package/dist/orchestrator/SwarmOrchestrator.js.map +1 -0
  82. package/dist/orchestrator/SwarmOrchestrator.test.d.ts +5 -0
  83. package/dist/orchestrator/SwarmOrchestrator.test.d.ts.map +1 -0
  84. package/dist/orchestrator/SwarmOrchestrator.test.js +95 -0
  85. package/dist/orchestrator/SwarmOrchestrator.test.js.map +1 -0
  86. package/dist/orchestrator/index.d.ts +2 -0
  87. package/dist/orchestrator/index.d.ts.map +1 -1
  88. package/dist/orchestrator/index.js +2 -0
  89. package/dist/orchestrator/index.js.map +1 -1
  90. package/dist/orchestrator/parallelResearch.js +24 -24
  91. package/dist/tools/convention/analyzeComplexity.test.js +115 -115
  92. package/dist/tools/convention/validateCodeQuality.test.js +104 -104
  93. package/dist/tools/spec/prdParser.test.js +171 -171
  94. package/dist/tools/spec/specGenerator.js +169 -169
  95. package/dist/tools/spec/traceabilityMatrix.js +64 -64
  96. package/dist/tools/spec/traceabilityMatrix.test.js +28 -28
  97. package/hooks/hooks.json +222 -222
  98. package/hooks/scripts/code-check.js +22 -22
  99. package/hooks/scripts/code-review.js +22 -22
  100. package/hooks/scripts/complexity.js +22 -22
  101. package/hooks/scripts/compound.js +23 -23
  102. package/hooks/scripts/context-save.js +33 -33
  103. package/hooks/scripts/gemini-ui-gen.js +281 -281
  104. package/hooks/scripts/generate-brand-assets.js +474 -474
  105. package/hooks/scripts/hud-multiline.js +262 -262
  106. package/hooks/scripts/hud-status.js +291 -291
  107. package/hooks/scripts/keyword-detector.js +214 -214
  108. package/hooks/scripts/llm-orchestrate.js +171 -171
  109. package/hooks/scripts/post-edit.js +97 -97
  110. package/hooks/scripts/post-tool-verify.js +210 -210
  111. package/hooks/scripts/pre-tool-guard.js +125 -125
  112. package/hooks/scripts/recall.js +22 -22
  113. package/hooks/scripts/session-start.js +30 -30
  114. package/hooks/scripts/skill-injector.js +191 -191
  115. package/hooks/scripts/utils.js +97 -97
  116. package/languages/csharp-unity.md +515 -515
  117. package/languages/gdscript-godot.md +470 -470
  118. package/languages/ruby-rails.md +489 -489
  119. package/languages/typescript-angular.md +433 -433
  120. package/languages/typescript-astro.md +416 -416
  121. package/languages/typescript-electron.md +406 -406
  122. package/languages/typescript-nestjs.md +524 -524
  123. package/languages/typescript-svelte.md +407 -407
  124. package/languages/typescript-tauri.md +365 -365
  125. package/package.json +84 -84
  126. package/skills/brand-assets.md +141 -141
  127. package/skills/commerce-patterns.md +361 -361
  128. package/skills/context7-usage.md +102 -102
  129. package/skills/e2e-commerce.md +304 -304
  130. package/skills/frontend-design.md +92 -92
  131. package/skills/git-worktree.md +181 -181
  132. package/skills/parallel-research.md +77 -77
  133. package/skills/priority-todos.md +239 -239
  134. package/skills/seo-checklist.md +244 -244
  135. package/skills/tool-fallback.md +190 -190
  136. package/skills/vibe-capabilities.md +161 -161
  137. package/vibe/constitution.md +227 -227
  138. package/vibe/rules/core/communication-guide.md +98 -98
  139. package/vibe/rules/core/development-philosophy.md +52 -52
  140. package/vibe/rules/core/quick-start.md +102 -102
  141. package/vibe/rules/quality/bdd-contract-testing.md +393 -393
  142. package/vibe/rules/quality/checklist.md +276 -276
  143. package/vibe/rules/quality/testing-strategy.md +440 -440
  144. package/vibe/rules/standards/anti-patterns.md +541 -541
  145. package/vibe/rules/standards/code-structure.md +291 -291
  146. package/vibe/rules/standards/complexity-metrics.md +313 -313
  147. package/vibe/rules/standards/naming-conventions.md +198 -198
  148. package/vibe/setup.sh +31 -31
  149. package/vibe/templates/constitution-template.md +252 -252
  150. package/vibe/templates/contract-backend-template.md +526 -526
  151. package/vibe/templates/contract-frontend-template.md +599 -599
  152. package/vibe/templates/feature-template.md +96 -96
  153. package/vibe/templates/spec-template.md +221 -221
  154. package/dist/cli/mcp.d.ts +0 -49
  155. package/dist/cli/mcp.d.ts.map +0 -1
  156. package/dist/cli/mcp.js +0 -169
  157. package/dist/cli/mcp.js.map +0 -1
  158. package/dist/lib/gemini-mcp.d.ts +0 -10
  159. package/dist/lib/gemini-mcp.d.ts.map +0 -1
  160. package/dist/lib/gemini-mcp.js +0 -353
  161. package/dist/lib/gemini-mcp.js.map +0 -1
  162. package/dist/lib/gpt-mcp.d.ts +0 -10
  163. package/dist/lib/gpt-mcp.d.ts.map +0 -1
  164. package/dist/lib/gpt-mcp.js +0 -352
  165. package/dist/lib/gpt-mcp.js.map +0 -1
  166. package/dist/tools/analytics/getUsageAnalytics.d.ts +0 -10
  167. package/dist/tools/analytics/getUsageAnalytics.d.ts.map +0 -1
  168. package/dist/tools/analytics/getUsageAnalytics.js +0 -246
  169. package/dist/tools/analytics/getUsageAnalytics.js.map +0 -1
  170. package/dist/tools/analytics/index.d.ts +0 -5
  171. package/dist/tools/analytics/index.d.ts.map +0 -1
  172. package/dist/tools/analytics/index.js +0 -5
  173. package/dist/tools/analytics/index.js.map +0 -1
  174. package/dist/tools/convention/getCodingGuide.d.ts +0 -7
  175. package/dist/tools/convention/getCodingGuide.d.ts.map +0 -1
  176. package/dist/tools/convention/getCodingGuide.js +0 -69
  177. package/dist/tools/convention/getCodingGuide.js.map +0 -1
  178. package/dist/tools/planning/analyzeRequirements.d.ts +0 -9
  179. package/dist/tools/planning/analyzeRequirements.d.ts.map +0 -1
  180. package/dist/tools/planning/analyzeRequirements.js +0 -171
  181. package/dist/tools/planning/analyzeRequirements.js.map +0 -1
  182. package/dist/tools/planning/createUserStories.d.ts +0 -9
  183. package/dist/tools/planning/createUserStories.d.ts.map +0 -1
  184. package/dist/tools/planning/createUserStories.js +0 -124
  185. package/dist/tools/planning/createUserStories.js.map +0 -1
  186. package/dist/tools/planning/featureRoadmap.d.ts +0 -10
  187. package/dist/tools/planning/featureRoadmap.d.ts.map +0 -1
  188. package/dist/tools/planning/featureRoadmap.js +0 -207
  189. package/dist/tools/planning/featureRoadmap.js.map +0 -1
  190. package/dist/tools/planning/generatePrd.d.ts +0 -11
  191. package/dist/tools/planning/generatePrd.d.ts.map +0 -1
  192. package/dist/tools/planning/generatePrd.js +0 -161
  193. package/dist/tools/planning/generatePrd.js.map +0 -1
  194. package/dist/tools/planning/index.d.ts +0 -8
  195. package/dist/tools/planning/index.d.ts.map +0 -1
  196. package/dist/tools/planning/index.js +0 -8
  197. package/dist/tools/planning/index.js.map +0 -1
  198. package/dist/tools/prompt/analyzePrompt.d.ts +0 -7
  199. package/dist/tools/prompt/analyzePrompt.d.ts.map +0 -1
  200. package/dist/tools/prompt/analyzePrompt.js +0 -150
  201. package/dist/tools/prompt/analyzePrompt.js.map +0 -1
  202. package/dist/tools/prompt/enhancePrompt.d.ts +0 -8
  203. package/dist/tools/prompt/enhancePrompt.d.ts.map +0 -1
  204. package/dist/tools/prompt/enhancePrompt.js +0 -110
  205. package/dist/tools/prompt/enhancePrompt.js.map +0 -1
  206. package/dist/tools/prompt/enhancePromptGemini.d.ts +0 -8
  207. package/dist/tools/prompt/enhancePromptGemini.d.ts.map +0 -1
  208. package/dist/tools/prompt/enhancePromptGemini.js +0 -332
  209. package/dist/tools/prompt/enhancePromptGemini.js.map +0 -1
  210. package/dist/tools/prompt/index.d.ts +0 -7
  211. package/dist/tools/prompt/index.d.ts.map +0 -1
  212. package/dist/tools/prompt/index.js +0 -7
  213. package/dist/tools/prompt/index.js.map +0 -1
  214. package/dist/tools/reasoning/applyReasoningFramework.d.ts +0 -8
  215. package/dist/tools/reasoning/applyReasoningFramework.d.ts.map +0 -1
  216. package/dist/tools/reasoning/applyReasoningFramework.js +0 -266
  217. package/dist/tools/reasoning/applyReasoningFramework.js.map +0 -1
  218. package/dist/tools/reasoning/index.d.ts +0 -5
  219. package/dist/tools/reasoning/index.d.ts.map +0 -1
  220. package/dist/tools/reasoning/index.js +0 -5
  221. package/dist/tools/reasoning/index.js.map +0 -1
  222. package/dist/tools/thinking/analyzeProblem.d.ts +0 -7
  223. package/dist/tools/thinking/analyzeProblem.d.ts.map +0 -1
  224. package/dist/tools/thinking/analyzeProblem.js +0 -55
  225. package/dist/tools/thinking/analyzeProblem.js.map +0 -1
  226. package/dist/tools/thinking/breakDownProblem.d.ts +0 -8
  227. package/dist/tools/thinking/breakDownProblem.d.ts.map +0 -1
  228. package/dist/tools/thinking/breakDownProblem.js +0 -145
  229. package/dist/tools/thinking/breakDownProblem.js.map +0 -1
  230. package/dist/tools/thinking/createThinkingChain.d.ts +0 -7
  231. package/dist/tools/thinking/createThinkingChain.d.ts.map +0 -1
  232. package/dist/tools/thinking/createThinkingChain.js +0 -44
  233. package/dist/tools/thinking/createThinkingChain.js.map +0 -1
  234. package/dist/tools/thinking/formatAsPlan.d.ts +0 -9
  235. package/dist/tools/thinking/formatAsPlan.d.ts.map +0 -1
  236. package/dist/tools/thinking/formatAsPlan.js +0 -78
  237. package/dist/tools/thinking/formatAsPlan.js.map +0 -1
  238. package/dist/tools/thinking/index.d.ts +0 -10
  239. package/dist/tools/thinking/index.d.ts.map +0 -1
  240. package/dist/tools/thinking/index.js +0 -10
  241. package/dist/tools/thinking/index.js.map +0 -1
  242. package/dist/tools/thinking/stepByStepAnalysis.d.ts +0 -8
  243. package/dist/tools/thinking/stepByStepAnalysis.d.ts.map +0 -1
  244. package/dist/tools/thinking/stepByStepAnalysis.js +0 -63
  245. package/dist/tools/thinking/stepByStepAnalysis.js.map +0 -1
  246. package/dist/tools/thinking/thinkAloudProcess.d.ts +0 -8
  247. package/dist/tools/thinking/thinkAloudProcess.d.ts.map +0 -1
  248. package/dist/tools/thinking/thinkAloudProcess.js +0 -80
  249. package/dist/tools/thinking/thinkAloudProcess.js.map +0 -1
@@ -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 |