cast-code 1.0.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.
Files changed (221) hide show
  1. package/LICENSE +21 -0
  2. package/README.md +217 -0
  3. package/dist/app.module.js +45 -0
  4. package/dist/app.module.js.map +1 -0
  5. package/dist/common/common.module.js +49 -0
  6. package/dist/common/common.module.js.map +1 -0
  7. package/dist/common/constants/index.js +105 -0
  8. package/dist/common/constants/index.js.map +1 -0
  9. package/dist/common/index.js +24 -0
  10. package/dist/common/index.js.map +1 -0
  11. package/dist/common/services/config.service.js +119 -0
  12. package/dist/common/services/config.service.js.map +1 -0
  13. package/dist/common/services/llm.service.js +56 -0
  14. package/dist/common/services/llm.service.js.map +1 -0
  15. package/dist/common/services/markdown-parser.service.js +101 -0
  16. package/dist/common/services/markdown-parser.service.js.map +1 -0
  17. package/dist/common/services/markdown-renderer.service.js +220 -0
  18. package/dist/common/services/markdown-renderer.service.js.map +1 -0
  19. package/dist/common/services/multi-llm.service.js +115 -0
  20. package/dist/common/services/multi-llm.service.js.map +1 -0
  21. package/dist/common/types/index.js +20 -0
  22. package/dist/common/types/index.js.map +1 -0
  23. package/dist/common/types/markdown.types.js +6 -0
  24. package/dist/common/types/markdown.types.js.map +1 -0
  25. package/dist/main.js +84 -0
  26. package/dist/main.js.map +1 -0
  27. package/dist/modules/agents/agents.module.js +43 -0
  28. package/dist/modules/agents/agents.module.js.map +1 -0
  29. package/dist/modules/agents/definitions/architect.md +35 -0
  30. package/dist/modules/agents/definitions/backend.md +43 -0
  31. package/dist/modules/agents/definitions/coder.md +34 -0
  32. package/dist/modules/agents/definitions/devops.md +42 -0
  33. package/dist/modules/agents/definitions/frontend.md +46 -0
  34. package/dist/modules/agents/definitions/reviewer.md +35 -0
  35. package/dist/modules/agents/definitions/tester.md +41 -0
  36. package/dist/modules/agents/index.js +23 -0
  37. package/dist/modules/agents/index.js.map +1 -0
  38. package/dist/modules/agents/services/agent-loader.service.js +150 -0
  39. package/dist/modules/agents/services/agent-loader.service.js.map +1 -0
  40. package/dist/modules/agents/services/agent-registry.service.js +108 -0
  41. package/dist/modules/agents/services/agent-registry.service.js.map +1 -0
  42. package/dist/modules/agents/types/agent.types.js +6 -0
  43. package/dist/modules/agents/types/agent.types.js.map +1 -0
  44. package/dist/modules/agents/types/index.js +20 -0
  45. package/dist/modules/agents/types/index.js.map +1 -0
  46. package/dist/modules/config/config.module.js +38 -0
  47. package/dist/modules/config/config.module.js.map +1 -0
  48. package/dist/modules/config/index.js +24 -0
  49. package/dist/modules/config/index.js.map +1 -0
  50. package/dist/modules/config/services/config-commands.service.js +405 -0
  51. package/dist/modules/config/services/config-commands.service.js.map +1 -0
  52. package/dist/modules/config/services/config-manager.service.js +175 -0
  53. package/dist/modules/config/services/config-manager.service.js.map +1 -0
  54. package/dist/modules/config/services/init-config.service.js +238 -0
  55. package/dist/modules/config/services/init-config.service.js.map +1 -0
  56. package/dist/modules/config/types/config.types.js +163 -0
  57. package/dist/modules/config/types/config.types.js.map +1 -0
  58. package/dist/modules/config/types/index.js +20 -0
  59. package/dist/modules/config/types/index.js.map +1 -0
  60. package/dist/modules/core/core.module.js +60 -0
  61. package/dist/modules/core/core.module.js.map +1 -0
  62. package/dist/modules/core/index.js +22 -0
  63. package/dist/modules/core/index.js.map +1 -0
  64. package/dist/modules/core/services/deep-agent.service.js +575 -0
  65. package/dist/modules/core/services/deep-agent.service.js.map +1 -0
  66. package/dist/modules/core/services/plan-mode.service.js +225 -0
  67. package/dist/modules/core/services/plan-mode.service.js.map +1 -0
  68. package/dist/modules/git/git.module.js +48 -0
  69. package/dist/modules/git/git.module.js.map +1 -0
  70. package/dist/modules/git/index.js +23 -0
  71. package/dist/modules/git/index.js.map +1 -0
  72. package/dist/modules/git/services/code-review.service.js +330 -0
  73. package/dist/modules/git/services/code-review.service.js.map +1 -0
  74. package/dist/modules/git/services/commit-generator.service.js +403 -0
  75. package/dist/modules/git/services/commit-generator.service.js.map +1 -0
  76. package/dist/modules/git/services/index.js +21 -0
  77. package/dist/modules/git/services/index.js.map +1 -0
  78. package/dist/modules/git/services/monorepo-detector.service.js +338 -0
  79. package/dist/modules/git/services/monorepo-detector.service.js.map +1 -0
  80. package/dist/modules/git/services/pr-generator.service.js +429 -0
  81. package/dist/modules/git/services/pr-generator.service.js.map +1 -0
  82. package/dist/modules/git/services/release-notes.service.js +426 -0
  83. package/dist/modules/git/services/release-notes.service.js.map +1 -0
  84. package/dist/modules/git/types/git.types.js +6 -0
  85. package/dist/modules/git/types/git.types.js.map +1 -0
  86. package/dist/modules/git/types/index.js +20 -0
  87. package/dist/modules/git/types/index.js.map +1 -0
  88. package/dist/modules/mcp/catalog/mcp-templates.js +606 -0
  89. package/dist/modules/mcp/catalog/mcp-templates.js.map +1 -0
  90. package/dist/modules/mcp/index.js +23 -0
  91. package/dist/modules/mcp/index.js.map +1 -0
  92. package/dist/modules/mcp/mcp.module.js +35 -0
  93. package/dist/modules/mcp/mcp.module.js.map +1 -0
  94. package/dist/modules/mcp/services/mcp-client.service.js +289 -0
  95. package/dist/modules/mcp/services/mcp-client.service.js.map +1 -0
  96. package/dist/modules/mcp/services/mcp-registry.service.js +197 -0
  97. package/dist/modules/mcp/services/mcp-registry.service.js.map +1 -0
  98. package/dist/modules/mcp/types/index.js +20 -0
  99. package/dist/modules/mcp/types/index.js.map +1 -0
  100. package/dist/modules/mcp/types/mcp.types.js +6 -0
  101. package/dist/modules/mcp/types/mcp.types.js.map +1 -0
  102. package/dist/modules/memory/index.js +23 -0
  103. package/dist/modules/memory/index.js.map +1 -0
  104. package/dist/modules/memory/memory.module.js +35 -0
  105. package/dist/modules/memory/memory.module.js.map +1 -0
  106. package/dist/modules/memory/services/memory-tools.service.js +78 -0
  107. package/dist/modules/memory/services/memory-tools.service.js.map +1 -0
  108. package/dist/modules/memory/services/memory.service.js +169 -0
  109. package/dist/modules/memory/services/memory.service.js.map +1 -0
  110. package/dist/modules/memory/types/index.js +20 -0
  111. package/dist/modules/memory/types/index.js.map +1 -0
  112. package/dist/modules/memory/types/memory.types.js +6 -0
  113. package/dist/modules/memory/types/memory.types.js.map +1 -0
  114. package/dist/modules/mentions/index.js +22 -0
  115. package/dist/modules/mentions/index.js.map +1 -0
  116. package/dist/modules/mentions/mentions.module.js +32 -0
  117. package/dist/modules/mentions/mentions.module.js.map +1 -0
  118. package/dist/modules/mentions/services/mentions.service.js +336 -0
  119. package/dist/modules/mentions/services/mentions.service.js.map +1 -0
  120. package/dist/modules/mentions/types/index.js +20 -0
  121. package/dist/modules/mentions/types/index.js.map +1 -0
  122. package/dist/modules/mentions/types/mention.types.js +19 -0
  123. package/dist/modules/mentions/types/mention.types.js.map +1 -0
  124. package/dist/modules/permissions/index.js +23 -0
  125. package/dist/modules/permissions/index.js.map +1 -0
  126. package/dist/modules/permissions/permissions.module.js +35 -0
  127. package/dist/modules/permissions/permissions.module.js.map +1 -0
  128. package/dist/modules/permissions/services/permission.service.js +269 -0
  129. package/dist/modules/permissions/services/permission.service.js.map +1 -0
  130. package/dist/modules/permissions/services/prompt.service.js +116 -0
  131. package/dist/modules/permissions/services/prompt.service.js.map +1 -0
  132. package/dist/modules/permissions/types/permission.types.js +32 -0
  133. package/dist/modules/permissions/types/permission.types.js.map +1 -0
  134. package/dist/modules/project/index.js +24 -0
  135. package/dist/modules/project/index.js.map +1 -0
  136. package/dist/modules/project/project.module.js +38 -0
  137. package/dist/modules/project/project.module.js.map +1 -0
  138. package/dist/modules/project/services/project-analyzer.service.js +1063 -0
  139. package/dist/modules/project/services/project-analyzer.service.js.map +1 -0
  140. package/dist/modules/project/services/project-context.service.js +62 -0
  141. package/dist/modules/project/services/project-context.service.js.map +1 -0
  142. package/dist/modules/project/services/project-loader.service.js +147 -0
  143. package/dist/modules/project/services/project-loader.service.js.map +1 -0
  144. package/dist/modules/project/types/index.js +20 -0
  145. package/dist/modules/project/types/index.js.map +1 -0
  146. package/dist/modules/project/types/project.types.js +6 -0
  147. package/dist/modules/project/types/project.types.js.map +1 -0
  148. package/dist/modules/repl/index.js +21 -0
  149. package/dist/modules/repl/index.js.map +1 -0
  150. package/dist/modules/repl/repl.module.js +66 -0
  151. package/dist/modules/repl/repl.module.js.map +1 -0
  152. package/dist/modules/repl/services/commands/agent-commands.service.js +196 -0
  153. package/dist/modules/repl/services/commands/agent-commands.service.js.map +1 -0
  154. package/dist/modules/repl/services/commands/git-commands.service.js +500 -0
  155. package/dist/modules/repl/services/commands/git-commands.service.js.map +1 -0
  156. package/dist/modules/repl/services/commands/mcp-commands.service.js +579 -0
  157. package/dist/modules/repl/services/commands/mcp-commands.service.js.map +1 -0
  158. package/dist/modules/repl/services/commands/project-commands.service.js +226 -0
  159. package/dist/modules/repl/services/commands/project-commands.service.js.map +1 -0
  160. package/dist/modules/repl/services/commands/repl-commands.service.js +254 -0
  161. package/dist/modules/repl/services/commands/repl-commands.service.js.map +1 -0
  162. package/dist/modules/repl/services/repl.service.js +647 -0
  163. package/dist/modules/repl/services/repl.service.js.map +1 -0
  164. package/dist/modules/repl/services/smart-input.js +544 -0
  165. package/dist/modules/repl/services/smart-input.js.map +1 -0
  166. package/dist/modules/repl/services/welcome-screen.service.js +117 -0
  167. package/dist/modules/repl/services/welcome-screen.service.js.map +1 -0
  168. package/dist/modules/repl/utils/prompts-with-esc.js +187 -0
  169. package/dist/modules/repl/utils/prompts-with-esc.js.map +1 -0
  170. package/dist/modules/repl/utils/theme.js +185 -0
  171. package/dist/modules/repl/utils/theme.js.map +1 -0
  172. package/dist/modules/skills/definitions/general/file-operations.md +60 -0
  173. package/dist/modules/skills/definitions/general/git-operations.md +59 -0
  174. package/dist/modules/skills/definitions/general/planning.md +86 -0
  175. package/dist/modules/skills/definitions/general/search.md +59 -0
  176. package/dist/modules/skills/definitions/specialized/api-design.md +85 -0
  177. package/dist/modules/skills/definitions/specialized/database-operations.md +78 -0
  178. package/dist/modules/skills/definitions/specialized/frontend-bootstrap.md +71 -0
  179. package/dist/modules/skills/definitions/specialized/react-patterns.md +77 -0
  180. package/dist/modules/skills/definitions/specialized/testing-strategies.md +79 -0
  181. package/dist/modules/skills/index.js +23 -0
  182. package/dist/modules/skills/index.js.map +1 -0
  183. package/dist/modules/skills/services/skill-loader.service.js +130 -0
  184. package/dist/modules/skills/services/skill-loader.service.js.map +1 -0
  185. package/dist/modules/skills/services/skill-registry.service.js +96 -0
  186. package/dist/modules/skills/services/skill-registry.service.js.map +1 -0
  187. package/dist/modules/skills/skills.module.js +38 -0
  188. package/dist/modules/skills/skills.module.js.map +1 -0
  189. package/dist/modules/skills/types/index.js +20 -0
  190. package/dist/modules/skills/types/index.js.map +1 -0
  191. package/dist/modules/skills/types/skill.types.js +6 -0
  192. package/dist/modules/skills/types/skill.types.js.map +1 -0
  193. package/dist/modules/tasks/index.js +24 -0
  194. package/dist/modules/tasks/index.js.map +1 -0
  195. package/dist/modules/tasks/services/plan-executor.service.js +199 -0
  196. package/dist/modules/tasks/services/plan-executor.service.js.map +1 -0
  197. package/dist/modules/tasks/services/plan-mode.service.js +118 -0
  198. package/dist/modules/tasks/services/plan-mode.service.js.map +1 -0
  199. package/dist/modules/tasks/services/plan-persistence.service.js +148 -0
  200. package/dist/modules/tasks/services/plan-persistence.service.js.map +1 -0
  201. package/dist/modules/tasks/services/task-management.service.js +255 -0
  202. package/dist/modules/tasks/services/task-management.service.js.map +1 -0
  203. package/dist/modules/tasks/services/task-tools.service.js +270 -0
  204. package/dist/modules/tasks/services/task-tools.service.js.map +1 -0
  205. package/dist/modules/tasks/tasks.module.js +49 -0
  206. package/dist/modules/tasks/tasks.module.js.map +1 -0
  207. package/dist/modules/tasks/types/task.types.js +21 -0
  208. package/dist/modules/tasks/types/task.types.js.map +1 -0
  209. package/dist/modules/tools/index.js +24 -0
  210. package/dist/modules/tools/index.js.map +1 -0
  211. package/dist/modules/tools/services/filesystem-tools.service.js +450 -0
  212. package/dist/modules/tools/services/filesystem-tools.service.js.map +1 -0
  213. package/dist/modules/tools/services/search-tools.service.js +63 -0
  214. package/dist/modules/tools/services/search-tools.service.js.map +1 -0
  215. package/dist/modules/tools/services/shell-tools.service.js +194 -0
  216. package/dist/modules/tools/services/shell-tools.service.js.map +1 -0
  217. package/dist/modules/tools/services/tools-registry.service.js +83 -0
  218. package/dist/modules/tools/services/tools-registry.service.js.map +1 -0
  219. package/dist/modules/tools/tools.module.js +46 -0
  220. package/dist/modules/tools/tools.module.js.map +1 -0
  221. package/package.json +74 -0
@@ -0,0 +1,429 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", {
3
+ value: true
4
+ });
5
+ Object.defineProperty(exports, "PrGeneratorService", {
6
+ enumerable: true,
7
+ get: function() {
8
+ return PrGeneratorService;
9
+ }
10
+ });
11
+ const _common = require("@nestjs/common");
12
+ const _child_process = require("child_process");
13
+ const _messages = require("@langchain/core/messages");
14
+ const _multillmservice = require("../../../common/services/multi-llm.service");
15
+ const _monorepodetectorservice = require("./monorepo-detector.service");
16
+ function _ts_decorate(decorators, target, key, desc) {
17
+ var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
18
+ if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
19
+ else for(var i = decorators.length - 1; i >= 0; i--)if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
20
+ return c > 3 && r && Object.defineProperty(target, key, r), r;
21
+ }
22
+ function _ts_metadata(k, v) {
23
+ if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
24
+ }
25
+ let PrGeneratorService = class PrGeneratorService {
26
+ getCurrentBranch() {
27
+ try {
28
+ return (0, _child_process.execSync)('git branch --show-current', {
29
+ cwd: process.cwd(),
30
+ encoding: 'utf-8'
31
+ }).trim();
32
+ } catch {
33
+ return 'unknown';
34
+ }
35
+ }
36
+ detectDefaultBaseBranch() {
37
+ try {
38
+ const cwd = process.cwd();
39
+ const candidates = [
40
+ 'main',
41
+ 'master',
42
+ 'develop'
43
+ ];
44
+ for (const branch of candidates){
45
+ try {
46
+ (0, _child_process.execSync)(`git rev-parse --verify ${branch} 2>/dev/null || git rev-parse --verify origin/${branch} 2>/dev/null`, {
47
+ cwd,
48
+ stdio: 'ignore'
49
+ });
50
+ return branch;
51
+ } catch {}
52
+ }
53
+ return 'main';
54
+ } catch {
55
+ return 'main';
56
+ }
57
+ }
58
+ detectPlatform() {
59
+ try {
60
+ const remoteUrl = (0, _child_process.execSync)('git remote get-url origin', {
61
+ cwd: process.cwd(),
62
+ encoding: 'utf-8'
63
+ }).trim();
64
+ if (remoteUrl.includes('github.com')) {
65
+ return {
66
+ platform: 'github',
67
+ url: remoteUrl
68
+ };
69
+ }
70
+ if (remoteUrl.includes('dev.azure.com') || remoteUrl.includes('visualstudio.com')) {
71
+ return {
72
+ platform: 'azure',
73
+ url: remoteUrl
74
+ };
75
+ }
76
+ if (remoteUrl.includes('gitlab.com') || remoteUrl.includes('gitlab')) {
77
+ return {
78
+ platform: 'gitlab',
79
+ url: remoteUrl
80
+ };
81
+ }
82
+ if (remoteUrl.includes('bitbucket.org')) {
83
+ return {
84
+ platform: 'bitbucket',
85
+ url: remoteUrl
86
+ };
87
+ }
88
+ return {
89
+ platform: 'unknown',
90
+ url: remoteUrl
91
+ };
92
+ } catch {
93
+ return {
94
+ platform: 'unknown',
95
+ url: ''
96
+ };
97
+ }
98
+ }
99
+ getCommitsNotInBase(baseBranch = 'develop') {
100
+ try {
101
+ const cwd = process.cwd();
102
+ try {
103
+ (0, _child_process.execSync)(`git rev-parse --verify ${baseBranch}`, {
104
+ cwd,
105
+ stdio: 'ignore'
106
+ });
107
+ } catch {
108
+ try {
109
+ (0, _child_process.execSync)(`git rev-parse --verify origin/${baseBranch}`, {
110
+ cwd,
111
+ stdio: 'ignore'
112
+ });
113
+ } catch {
114
+ return [];
115
+ }
116
+ }
117
+ const logOutput = (0, _child_process.execSync)(`git log ${baseBranch}..HEAD --pretty=format:"%H|%s|%an|%ad" --date=short`, {
118
+ cwd,
119
+ encoding: 'utf-8'
120
+ });
121
+ if (!logOutput.trim()) {
122
+ return [];
123
+ }
124
+ const commits = [];
125
+ const lines = logOutput.trim().split('\n');
126
+ for (const line of lines){
127
+ const [hash, message, author, date] = line.split('|');
128
+ if (!hash) continue;
129
+ const filesOutput = (0, _child_process.execSync)(`git diff-tree --no-commit-id --name-only -r ${hash}`, {
130
+ cwd,
131
+ encoding: 'utf-8'
132
+ });
133
+ const files = filesOutput.trim().split('\n').filter((f)=>f);
134
+ const diffOutput = (0, _child_process.execSync)(`git show ${hash} --stat`, {
135
+ cwd,
136
+ encoding: 'utf-8'
137
+ });
138
+ commits.push({
139
+ hash: hash.slice(0, 7),
140
+ message,
141
+ author,
142
+ date,
143
+ files,
144
+ diff: diffOutput
145
+ });
146
+ }
147
+ return commits.reverse();
148
+ } catch (error) {
149
+ return [];
150
+ }
151
+ }
152
+ async analyzeCommit(commit) {
153
+ const llm = this.multiLlmService.createModel('cheap');
154
+ const prompt = this.buildCommitAnalysisPrompt(commit);
155
+ const response = await llm.invoke([
156
+ new _messages.SystemMessage(this.getCommitAnalysisSystemPrompt()),
157
+ new _messages.HumanMessage(prompt)
158
+ ]);
159
+ const content = this.extractContent(response.content);
160
+ return this.parseCommitAnalysis(content);
161
+ }
162
+ async generatePRDescription(branchName, commits, baseBranch = 'develop') {
163
+ const llm = this.multiLlmService.createModel('cheap');
164
+ const prompt = this.buildSinglePrompt(branchName, commits, baseBranch);
165
+ const response = await llm.invoke([
166
+ new _messages.SystemMessage(this.getSingleAgentSystemPrompt()),
167
+ new _messages.HumanMessage(prompt)
168
+ ]);
169
+ const content = this.extractContent(response.content);
170
+ const { title, description, commitSummaries } = this.parseSingleResponse(content, commits);
171
+ return {
172
+ title: title || this.generateDefaultTitle(branchName),
173
+ description,
174
+ commits: commitSummaries
175
+ };
176
+ }
177
+ async createPR(title, description, baseBranch = 'develop') {
178
+ const { platform } = this.detectPlatform();
179
+ const branch = this.getCurrentBranch();
180
+ if (platform !== 'github') {
181
+ return {
182
+ success: false,
183
+ error: `Automatic PR creation not supported for ${platform}. Description generated and copied to clipboard.`,
184
+ description: this.formatPRForClipboard(title, description, baseBranch),
185
+ platform
186
+ };
187
+ }
188
+ try {
189
+ (0, _child_process.execSync)('which gh', {
190
+ cwd: process.cwd()
191
+ });
192
+ } catch {
193
+ return {
194
+ success: false,
195
+ error: 'GitHub CLI (gh) not found. Install from https://cli.github.com/',
196
+ description: this.formatPRForClipboard(title, description, baseBranch),
197
+ platform
198
+ };
199
+ }
200
+ try {
201
+ const cwd = process.cwd();
202
+ const tempFile = `/tmp/pr-body-${Date.now()}.md`;
203
+ require('fs').writeFileSync(tempFile, description);
204
+ try {
205
+ const result = (0, _child_process.execSync)(`gh pr create --title "${title.replace(/"/g, '\\"')}" --body-file "${tempFile}" --base "${baseBranch}"`, {
206
+ cwd,
207
+ encoding: 'utf-8'
208
+ });
209
+ const urlMatch = result.match(/https:\/\/github\.com\/[^\s]+/);
210
+ return {
211
+ success: true,
212
+ url: urlMatch ? urlMatch[0] : undefined,
213
+ platform
214
+ };
215
+ } finally{
216
+ try {
217
+ require('fs').unlinkSync(tempFile);
218
+ } catch {}
219
+ }
220
+ } catch (error) {
221
+ const message = error.message || 'Failed to create PR';
222
+ if (message.includes('already exists')) {
223
+ return {
224
+ success: false,
225
+ error: 'A PR already exists for this branch',
226
+ description: this.formatPRForClipboard(title, description, baseBranch),
227
+ platform
228
+ };
229
+ }
230
+ return {
231
+ success: false,
232
+ error: message,
233
+ description: this.formatPRForClipboard(title, description, baseBranch),
234
+ platform
235
+ };
236
+ }
237
+ }
238
+ copyToClipboard(text) {
239
+ try {
240
+ const platform = process.platform;
241
+ if (platform === 'darwin') {
242
+ (0, _child_process.execSync)(`echo ${JSON.stringify(text)} | pbcopy`);
243
+ return true;
244
+ } else if (platform === 'linux') {
245
+ try {
246
+ (0, _child_process.execSync)(`echo ${JSON.stringify(text)} | xclip -selection clipboard`);
247
+ return true;
248
+ } catch {
249
+ try {
250
+ (0, _child_process.execSync)(`echo ${JSON.stringify(text)} | xsel --clipboard --input`);
251
+ return true;
252
+ } catch {
253
+ return false;
254
+ }
255
+ }
256
+ } else if (platform === 'win32') {
257
+ (0, _child_process.execSync)(`echo ${JSON.stringify(text)} | clip`);
258
+ return true;
259
+ }
260
+ return false;
261
+ } catch {
262
+ return false;
263
+ }
264
+ }
265
+ formatPRForClipboard(title, description, baseBranch) {
266
+ return `# ${title}\n\n${description}\n\n---\n**Base Branch:** ${baseBranch}\n**Generated by:** Cast Code`;
267
+ }
268
+ getPRCreateUrl(platform, baseBranch) {
269
+ try {
270
+ const remoteUrl = (0, _child_process.execSync)('git remote get-url origin', {
271
+ cwd: process.cwd(),
272
+ encoding: 'utf-8'
273
+ }).trim();
274
+ const branch = this.getCurrentBranch();
275
+ let httpsUrl = remoteUrl.replace(/^git@github\.com:/, 'https://github.com/').replace(/^git@gitlab\.com:/, 'https://gitlab.com/').replace(/^git@bitbucket\.org:/, 'https://bitbucket.org/').replace(/\.git$/, '');
276
+ switch(platform){
277
+ case 'github':
278
+ return `${httpsUrl}/compare/${baseBranch}...${branch}?expand=1`;
279
+ case 'gitlab':
280
+ return `${httpsUrl}/merge_requests/new?merge_request[source_branch]=${branch}&merge_request[target_branch]=${baseBranch}`;
281
+ case 'bitbucket':
282
+ return `${httpsUrl}/pull-requests/new?source=${branch}&dest=${baseBranch}`;
283
+ case 'azure':
284
+ return null;
285
+ default:
286
+ return null;
287
+ }
288
+ } catch {
289
+ return null;
290
+ }
291
+ }
292
+ buildCommitAnalysisPrompt(commit) {
293
+ const monorepoInfo = this.monorepoDetector.detectMonorepo(process.cwd());
294
+ const scope = this.monorepoDetector.determineScope(commit.files, monorepoInfo);
295
+ return `Analyze this commit:\n\n**Commit:** ${commit.hash}\n**Message:** ${commit.message}\n**Author:** ${commit.author}\n**Date:** ${commit.date}\n**Scope:** ${scope || 'general'}\n\n**Files Changed:**\n${commit.files.join('\n')}\n\n**Diff Stats:**\n${commit.diff}\n\nProvide:\n1. A one-line summary (max 100 chars)\n2. Detailed explanation of changes, approach, and impact`;
296
+ }
297
+ buildPRDescriptionPrompt(branchName, commits, baseBranch) {
298
+ const commitsSummary = commits.map((c, i)=>`${i + 1}. **${c.hash}** - ${c.summary}\n ${c.details.slice(0, 200)}...`).join('\n\n');
299
+ return `Create a PR description for branch "${branchName}" to "${baseBranch}".\n\n**Commits:**\n${commitsSummary}\n\nGenerate:\n1. PR title (use branch name as inspiration)\n2. Description with: Overview, Changes, Technical Details, Testing`;
300
+ }
301
+ getCommitAnalysisSystemPrompt() {
302
+ return `Analyze a git commit. Provide:\n\n1. **Summary**: One sentence (max 100 chars)\n2. **Details**: Detailed paragraph about changes\n\nFormat:\nSUMMARY: <summary>\n\nDETAILS: <details>`;
303
+ }
304
+ getPRDescriptionSystemPrompt() {
305
+ return `Create a Pull Request description.\n\n**Title:** Concise, descriptive\n\n**Description Structure:**\n\`\`\`markdown\n## Overview\nBrief explanation\n\n## Changes\n- Change 1\n- Change 2\n\n## Technical Details\nImplementation details\n\n## Testing\nHow to test\n\`\`\``;
306
+ }
307
+ parseCommitAnalysis(content) {
308
+ const summaryMatch = content.match(/SUMMARY:\s*(.+?)(?=\n\n|DETAILS:|$)/is);
309
+ const detailsMatch = content.match(/DETAILS:\s*(.+?)$/is);
310
+ return {
311
+ summary: summaryMatch ? summaryMatch[1].trim() : 'No summary available',
312
+ details: detailsMatch ? detailsMatch[1].trim() : content
313
+ };
314
+ }
315
+ parsePRDescription(content) {
316
+ const titleMatch = content.match(/^#?\s*Title:?\s*(.+?)(?=\n\n|\n##|$)/i);
317
+ const lines = content.split('\n');
318
+ const title = titleMatch ? titleMatch[1].trim() : lines[0].replace(/^#+\s*/, '').trim();
319
+ const description = titleMatch ? content.slice(content.indexOf(titleMatch[0]) + titleMatch[0].length).trim() : lines.slice(1).join('\n').trim();
320
+ return {
321
+ title,
322
+ description
323
+ };
324
+ }
325
+ buildSinglePrompt(branchName, commits, baseBranch) {
326
+ const commitsInfo = commits.map((c, i)=>`${i + 1}. **${c.hash}** - ${c.message}\n Files: ${c.files.slice(0, 5).join(', ')}${c.files.length > 5 ? '...' : ''}\n Stats: ${c.diff.split('\n').slice(-3, -1).join(' ')}`).join('\n\n');
327
+ return `Branch: ${branchName}\nBase: ${baseBranch}\nCommits: ${commits.length}\n\n${commitsInfo}`;
328
+ }
329
+ getSingleAgentSystemPrompt() {
330
+ return `You are a senior developer creating a Pull Request description. Analyze ALL commits and generate a comprehensive PR description.
331
+
332
+ **OUTPUT FORMAT:**
333
+ TITLE: <PR title based on branch name and overall changes>
334
+
335
+ OVERVIEW: <2-3 sentences explaining what this PR accomplishes>
336
+
337
+ CHANGES:
338
+ - <key change 1>
339
+ - <key change 2>
340
+ - ...
341
+
342
+ TECHNICAL_DETAILS: <important implementation details, architecture decisions>
343
+
344
+ COMMITS:
345
+ <hash>: <one-line summary of what this commit does>
346
+ (repeat for each commit)
347
+
348
+ TESTING: <how to test these changes>`;
349
+ }
350
+ parseSingleResponse(content, commits) {
351
+ const titleMatch = content.match(/TITLE:\s*(.+?)(?=\n\n|\n[A-Z]|$)/i);
352
+ const overviewMatch = content.match(/OVERVIEW:\s*([\s\S]+?)(?=\n\nCHANGES:|CHANGES:)/i);
353
+ const changesMatch = content.match(/CHANGES:\s*([\s\S]+?)(?=\n\nTECHNICAL_DETAILS:|TECHNICAL_DETAILS:)/i);
354
+ const technicalMatch = content.match(/TECHNICAL_DETAILS:\s*([\s\S]+?)(?=\n\nCOMMITS:|COMMITS:)/i);
355
+ const commitsMatch = content.match(/COMMITS:\s*([\s\S]+?)(?=\n\nTESTING:|TESTING:|$)/i);
356
+ const testingMatch = content.match(/TESTING:\s*([\s\S]+)$/i);
357
+ const title = titleMatch ? titleMatch[1].trim() : '';
358
+ const parts = [];
359
+ if (overviewMatch) {
360
+ parts.push('## Overview\n' + overviewMatch[1].trim());
361
+ }
362
+ if (changesMatch) {
363
+ parts.push('## Changes\n' + changesMatch[1].trim());
364
+ }
365
+ if (technicalMatch) {
366
+ parts.push('## Technical Details\n' + technicalMatch[1].trim());
367
+ }
368
+ if (testingMatch) {
369
+ parts.push('## Testing\n' + testingMatch[1].trim());
370
+ }
371
+ const description = parts.join('\n\n');
372
+ const commitSummaries = [];
373
+ if (commitsMatch) {
374
+ const commitsText = commitsMatch[1].trim();
375
+ const lines = commitsText.split('\n');
376
+ for (const line of lines){
377
+ const match = line.match(/^([a-f0-9]+):\s*(.+)$/i);
378
+ if (match) {
379
+ commitSummaries.push({
380
+ hash: match[1].slice(0, 7),
381
+ summary: match[2].trim(),
382
+ details: ''
383
+ });
384
+ }
385
+ }
386
+ }
387
+ if (commitSummaries.length === 0) {
388
+ for (const commit of commits){
389
+ commitSummaries.push({
390
+ hash: commit.hash,
391
+ summary: commit.message.slice(0, 60),
392
+ details: ''
393
+ });
394
+ }
395
+ }
396
+ return {
397
+ title,
398
+ description,
399
+ commitSummaries
400
+ };
401
+ }
402
+ generateDefaultTitle(branchName) {
403
+ return branchName.replace(/^(feature|fix|hotfix|release)\//, '').split(/[-_]/).map((word)=>word.charAt(0).toUpperCase() + word.slice(1)).join(' ');
404
+ }
405
+ extractContent(content) {
406
+ if (typeof content === 'string') return content;
407
+ if (Array.isArray(content) && content.length > 0) {
408
+ const first = content[0];
409
+ if (typeof first === 'object' && first !== null && 'text' in first) {
410
+ return String(first.text);
411
+ }
412
+ }
413
+ return String(content);
414
+ }
415
+ constructor(multiLlmService, monorepoDetector){
416
+ this.multiLlmService = multiLlmService;
417
+ this.monorepoDetector = monorepoDetector;
418
+ }
419
+ };
420
+ PrGeneratorService = _ts_decorate([
421
+ (0, _common.Injectable)(),
422
+ _ts_metadata("design:type", Function),
423
+ _ts_metadata("design:paramtypes", [
424
+ typeof _multillmservice.MultiLlmService === "undefined" ? Object : _multillmservice.MultiLlmService,
425
+ typeof _monorepodetectorservice.MonorepoDetectorService === "undefined" ? Object : _monorepodetectorservice.MonorepoDetectorService
426
+ ])
427
+ ], PrGeneratorService);
428
+
429
+ //# sourceMappingURL=pr-generator.service.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../../../../src/modules/git/services/pr-generator.service.ts"],"sourcesContent":["import { Injectable } from '@nestjs/common';\nimport { execSync } from 'child_process';\nimport { HumanMessage, SystemMessage } from '@langchain/core/messages';\nimport { MultiLlmService } from '../../../common/services/multi-llm.service';\nimport { MonorepoDetectorService } from './monorepo-detector.service';\n\nexport interface CommitInfo {\n hash: string;\n message: string;\n author: string;\n date: string;\n files: string[];\n diff: string;\n}\n\nexport interface PRDescription {\n title: string;\n description: string;\n commits: { hash: string; summary: string; details: string }[];\n}\n\nexport interface PRCreationResult {\n success: boolean;\n url?: string;\n error?: string;\n description?: string;\n platform: 'github' | 'azure' | 'gitlab' | 'bitbucket' | 'unknown';\n}\n\n@Injectable()\nexport class PrGeneratorService {\n constructor(\n private readonly multiLlmService: MultiLlmService,\n private readonly monorepoDetector: MonorepoDetectorService,\n ) {}\n\n getCurrentBranch(): string {\n try {\n return execSync('git branch --show-current', { \n cwd: process.cwd(), \n encoding: 'utf-8' \n }).trim();\n } catch {\n return 'unknown';\n }\n }\n\n detectDefaultBaseBranch(): string {\n try {\n const cwd = process.cwd();\n const candidates = ['main', 'master', 'develop'];\n \n for (const branch of candidates) {\n try {\n execSync(`git rev-parse --verify ${branch} 2>/dev/null || git rev-parse --verify origin/${branch} 2>/dev/null`, { \n cwd, \n stdio: 'ignore' \n });\n return branch;\n } catch {\n }\n }\n \n return 'main';\n } catch {\n return 'main';\n }\n }\n\n detectPlatform(): { platform: 'github' | 'azure' | 'gitlab' | 'bitbucket' | 'unknown'; url: string } {\n try {\n const remoteUrl = execSync('git remote get-url origin', { \n cwd: process.cwd(), \n encoding: 'utf-8' \n }).trim();\n\n if (remoteUrl.includes('github.com')) {\n return { platform: 'github', url: remoteUrl };\n }\n if (remoteUrl.includes('dev.azure.com') || remoteUrl.includes('visualstudio.com')) {\n return { platform: 'azure', url: remoteUrl };\n }\n if (remoteUrl.includes('gitlab.com') || remoteUrl.includes('gitlab')) {\n return { platform: 'gitlab', url: remoteUrl };\n }\n if (remoteUrl.includes('bitbucket.org')) {\n return { platform: 'bitbucket', url: remoteUrl };\n }\n\n return { platform: 'unknown', url: remoteUrl };\n } catch {\n return { platform: 'unknown', url: '' };\n }\n }\n\n getCommitsNotInBase(baseBranch: string = 'develop'): CommitInfo[] {\n try {\n const cwd = process.cwd();\n \n try {\n execSync(`git rev-parse --verify ${baseBranch}`, { cwd, stdio: 'ignore' });\n } catch {\n try {\n execSync(`git rev-parse --verify origin/${baseBranch}`, { cwd, stdio: 'ignore' });\n } catch {\n return [];\n }\n }\n\n const logOutput = execSync(\n `git log ${baseBranch}..HEAD --pretty=format:\"%H|%s|%an|%ad\" --date=short`,\n { cwd, encoding: 'utf-8' }\n );\n\n if (!logOutput.trim()) {\n return [];\n }\n\n const commits: CommitInfo[] = [];\n const lines = logOutput.trim().split('\\n');\n\n for (const line of lines) {\n const [hash, message, author, date] = line.split('|');\n if (!hash) continue;\n\n const filesOutput = execSync(\n `git diff-tree --no-commit-id --name-only -r ${hash}`,\n { cwd, encoding: 'utf-8' }\n );\n const files = filesOutput.trim().split('\\n').filter(f => f);\n\n const diffOutput = execSync(\n `git show ${hash} --stat`,\n { cwd, encoding: 'utf-8' }\n );\n\n commits.push({\n hash: hash.slice(0, 7),\n message,\n author,\n date,\n files,\n diff: diffOutput,\n });\n }\n\n return commits.reverse();\n } catch (error) {\n return [];\n }\n }\n\n async analyzeCommit(commit: CommitInfo): Promise<{ summary: string; details: string }> {\n const llm = this.multiLlmService.createModel('cheap');\n\n const prompt = this.buildCommitAnalysisPrompt(commit);\n\n const response = await llm.invoke([\n new SystemMessage(this.getCommitAnalysisSystemPrompt()),\n new HumanMessage(prompt),\n ]);\n\n const content = this.extractContent(response.content);\n return this.parseCommitAnalysis(content);\n }\n\n async generatePRDescription(\n branchName: string, \n commits: CommitInfo[],\n baseBranch: string = 'develop',\n ): Promise<PRDescription> {\n const llm = this.multiLlmService.createModel('cheap');\n const prompt = this.buildSinglePrompt(branchName, commits, baseBranch);\n\n const response = await llm.invoke([\n new SystemMessage(this.getSingleAgentSystemPrompt()),\n new HumanMessage(prompt),\n ]);\n\n const content = this.extractContent(response.content);\n const { title, description, commitSummaries } = this.parseSingleResponse(content, commits);\n\n return {\n title: title || this.generateDefaultTitle(branchName),\n description,\n commits: commitSummaries,\n };\n }\n\n async createPR(\n title: string, \n description: string, \n baseBranch: string = 'develop'\n ): Promise<PRCreationResult> {\n const { platform } = this.detectPlatform();\n const branch = this.getCurrentBranch();\n\n if (platform !== 'github') {\n return {\n success: false,\n error: `Automatic PR creation not supported for ${platform}. Description generated and copied to clipboard.`,\n description: this.formatPRForClipboard(title, description, baseBranch),\n platform,\n };\n }\n\n try {\n execSync('which gh', { cwd: process.cwd() });\n } catch {\n return {\n success: false,\n error: 'GitHub CLI (gh) not found. Install from https://cli.github.com/',\n description: this.formatPRForClipboard(title, description, baseBranch),\n platform,\n };\n }\n\n try {\n const cwd = process.cwd();\n\n const tempFile = `/tmp/pr-body-${Date.now()}.md`;\n require('fs').writeFileSync(tempFile, description);\n\n try {\n const result = execSync(\n `gh pr create --title \"${title.replace(/\"/g, '\\\\\"')}\" --body-file \"${tempFile}\" --base \"${baseBranch}\"`,\n { cwd, encoding: 'utf-8' }\n );\n \n const urlMatch = result.match(/https:\\/\\/github\\.com\\/[^\\s]+/);\n \n return { \n success: true, \n url: urlMatch ? urlMatch[0] : undefined,\n platform,\n };\n } finally {\n try {\n require('fs').unlinkSync(tempFile);\n } catch {}\n }\n } catch (error: any) {\n const message = error.message || 'Failed to create PR';\n if (message.includes('already exists')) {\n return { \n success: false, \n error: 'A PR already exists for this branch',\n description: this.formatPRForClipboard(title, description, baseBranch),\n platform,\n };\n }\n return { \n success: false, \n error: message,\n description: this.formatPRForClipboard(title, description, baseBranch),\n platform,\n };\n }\n }\n\n copyToClipboard(text: string): boolean {\n try {\n const platform = process.platform;\n \n if (platform === 'darwin') {\n execSync(`echo ${JSON.stringify(text)} | pbcopy`);\n return true;\n } else if (platform === 'linux') {\n try {\n execSync(`echo ${JSON.stringify(text)} | xclip -selection clipboard`);\n return true;\n } catch {\n try {\n execSync(`echo ${JSON.stringify(text)} | xsel --clipboard --input`);\n return true;\n } catch {\n return false;\n }\n }\n } else if (platform === 'win32') {\n execSync(`echo ${JSON.stringify(text)} | clip`);\n return true;\n }\n \n return false;\n } catch {\n return false;\n }\n }\n\n formatPRForClipboard(title: string, description: string, baseBranch: string): string {\n return `# ${title}\\n\\n${description}\\n\\n---\\n**Base Branch:** ${baseBranch}\\n**Generated by:** Cast Code`;\n }\n\n getPRCreateUrl(platform: string, baseBranch: string): string | null {\n try {\n const remoteUrl = execSync('git remote get-url origin', { \n cwd: process.cwd(), \n encoding: 'utf-8' \n }).trim();\n\n const branch = this.getCurrentBranch();\n\n let httpsUrl = remoteUrl\n .replace(/^git@github\\.com:/, 'https://github.com/')\n .replace(/^git@gitlab\\.com:/, 'https://gitlab.com/')\n .replace(/^git@bitbucket\\.org:/, 'https://bitbucket.org/')\n .replace(/\\.git$/, '');\n\n switch (platform) {\n case 'github':\n return `${httpsUrl}/compare/${baseBranch}...${branch}?expand=1`;\n case 'gitlab':\n return `${httpsUrl}/merge_requests/new?merge_request[source_branch]=${branch}&merge_request[target_branch]=${baseBranch}`;\n case 'bitbucket':\n return `${httpsUrl}/pull-requests/new?source=${branch}&dest=${baseBranch}`;\n case 'azure':\n return null;\n default:\n return null;\n }\n } catch {\n return null;\n }\n }\n\n private buildCommitAnalysisPrompt(commit: CommitInfo): string {\n const monorepoInfo = this.monorepoDetector.detectMonorepo(process.cwd());\n const scope = this.monorepoDetector.determineScope(commit.files, monorepoInfo);\n\n return `Analyze this commit:\\n\\n**Commit:** ${commit.hash}\\n**Message:** ${commit.message}\\n**Author:** ${commit.author}\\n**Date:** ${commit.date}\\n**Scope:** ${scope || 'general'}\\n\\n**Files Changed:**\\n${commit.files.join('\\n')}\\n\\n**Diff Stats:**\\n${commit.diff}\\n\\nProvide:\\n1. A one-line summary (max 100 chars)\\n2. Detailed explanation of changes, approach, and impact`;\n }\n\n private buildPRDescriptionPrompt(\n branchName: string, \n commits: { hash: string; message: string; summary: string; details: string }[],\n baseBranch: string,\n ): string {\n const commitsSummary = commits.map((c, i) => \n `${i + 1}. **${c.hash}** - ${c.summary}\\n ${c.details.slice(0, 200)}...`\n ).join('\\n\\n');\n\n return `Create a PR description for branch \"${branchName}\" to \"${baseBranch}\".\\n\\n**Commits:**\\n${commitsSummary}\\n\\nGenerate:\\n1. PR title (use branch name as inspiration)\\n2. Description with: Overview, Changes, Technical Details, Testing`;\n }\n\n private getCommitAnalysisSystemPrompt(): string {\n return `Analyze a git commit. Provide:\\n\\n1. **Summary**: One sentence (max 100 chars)\\n2. **Details**: Detailed paragraph about changes\\n\\nFormat:\\nSUMMARY: <summary>\\n\\nDETAILS: <details>`;\n }\n\n private getPRDescriptionSystemPrompt(): string {\n return `Create a Pull Request description.\\n\\n**Title:** Concise, descriptive\\n\\n**Description Structure:**\\n\\`\\`\\`markdown\\n## Overview\\nBrief explanation\\n\\n## Changes\\n- Change 1\\n- Change 2\\n\\n## Technical Details\\nImplementation details\\n\\n## Testing\\nHow to test\\n\\`\\`\\``;\n }\n\n private parseCommitAnalysis(content: string): { summary: string; details: string } {\n const summaryMatch = content.match(/SUMMARY:\\s*(.+?)(?=\\n\\n|DETAILS:|$)/is);\n const detailsMatch = content.match(/DETAILS:\\s*(.+?)$/is);\n\n return {\n summary: summaryMatch ? summaryMatch[1].trim() : 'No summary available',\n details: detailsMatch ? detailsMatch[1].trim() : content,\n };\n }\n\n private parsePRDescription(content: string): { title: string; description: string } {\n const titleMatch = content.match(/^#?\\s*Title:?\\s*(.+?)(?=\\n\\n|\\n##|$)/i);\n const lines = content.split('\\n');\n const title = titleMatch ? titleMatch[1].trim() : lines[0].replace(/^#+\\s*/, '').trim();\n const description = titleMatch \n ? content.slice(content.indexOf(titleMatch[0]) + titleMatch[0].length).trim()\n : lines.slice(1).join('\\n').trim();\n\n return { title, description };\n }\n\n private buildSinglePrompt(branchName: string, commits: CommitInfo[], baseBranch: string): string {\n const commitsInfo = commits.map((c, i) => \n `${i + 1}. **${c.hash}** - ${c.message}\\n Files: ${c.files.slice(0, 5).join(', ')}${c.files.length > 5 ? '...' : ''}\\n Stats: ${c.diff.split('\\n').slice(-3, -1).join(' ')}`\n ).join('\\n\\n');\n\n return `Branch: ${branchName}\\nBase: ${baseBranch}\\nCommits: ${commits.length}\\n\\n${commitsInfo}`;\n }\n\n private getSingleAgentSystemPrompt(): string {\n return `You are a senior developer creating a Pull Request description. Analyze ALL commits and generate a comprehensive PR description.\n\n**OUTPUT FORMAT:**\nTITLE: <PR title based on branch name and overall changes>\n\nOVERVIEW: <2-3 sentences explaining what this PR accomplishes>\n\nCHANGES:\n- <key change 1>\n- <key change 2>\n- ...\n\nTECHNICAL_DETAILS: <important implementation details, architecture decisions>\n\nCOMMITS:\n<hash>: <one-line summary of what this commit does>\n(repeat for each commit)\n\nTESTING: <how to test these changes>`;\n }\n\n private parseSingleResponse(content: string, commits: CommitInfo[]): { \n title: string; \n description: string; \n commitSummaries: { hash: string; summary: string; details: string }[] \n } {\n const titleMatch = content.match(/TITLE:\\s*(.+?)(?=\\n\\n|\\n[A-Z]|$)/i);\n const overviewMatch = content.match(/OVERVIEW:\\s*([\\s\\S]+?)(?=\\n\\nCHANGES:|CHANGES:)/i);\n const changesMatch = content.match(/CHANGES:\\s*([\\s\\S]+?)(?=\\n\\nTECHNICAL_DETAILS:|TECHNICAL_DETAILS:)/i);\n const technicalMatch = content.match(/TECHNICAL_DETAILS:\\s*([\\s\\S]+?)(?=\\n\\nCOMMITS:|COMMITS:)/i);\n const commitsMatch = content.match(/COMMITS:\\s*([\\s\\S]+?)(?=\\n\\nTESTING:|TESTING:|$)/i);\n const testingMatch = content.match(/TESTING:\\s*([\\s\\S]+)$/i);\n\n const title = titleMatch ? titleMatch[1].trim() : '';\n \n const parts: string[] = [];\n \n if (overviewMatch) {\n parts.push('## Overview\\n' + overviewMatch[1].trim());\n }\n \n if (changesMatch) {\n parts.push('## Changes\\n' + changesMatch[1].trim());\n }\n \n if (technicalMatch) {\n parts.push('## Technical Details\\n' + technicalMatch[1].trim());\n }\n \n if (testingMatch) {\n parts.push('## Testing\\n' + testingMatch[1].trim());\n }\n\n const description = parts.join('\\n\\n');\n\n const commitSummaries: { hash: string; summary: string; details: string }[] = [];\n \n if (commitsMatch) {\n const commitsText = commitsMatch[1].trim();\n const lines = commitsText.split('\\n');\n \n for (const line of lines) {\n const match = line.match(/^([a-f0-9]+):\\s*(.+)$/i);\n if (match) {\n commitSummaries.push({\n hash: match[1].slice(0, 7),\n summary: match[2].trim(),\n details: '',\n });\n }\n }\n }\n\n if (commitSummaries.length === 0) {\n for (const commit of commits) {\n commitSummaries.push({\n hash: commit.hash,\n summary: commit.message.slice(0, 60),\n details: '',\n });\n }\n }\n\n return { title, description, commitSummaries };\n }\n\n private generateDefaultTitle(branchName: string): string {\n return branchName\n .replace(/^(feature|fix|hotfix|release)\\//, '')\n .split(/[-_]/)\n .map(word => word.charAt(0).toUpperCase() + word.slice(1))\n .join(' ');\n }\n\n private extractContent(content: unknown): string {\n if (typeof content === 'string') return content;\n if (Array.isArray(content) && content.length > 0) {\n const first = content[0];\n if (typeof first === 'object' && first !== null && 'text' in first) {\n return String(first.text);\n }\n }\n return String(content);\n }\n}\n"],"names":["PrGeneratorService","getCurrentBranch","execSync","cwd","process","encoding","trim","detectDefaultBaseBranch","candidates","branch","stdio","detectPlatform","remoteUrl","includes","platform","url","getCommitsNotInBase","baseBranch","logOutput","commits","lines","split","line","hash","message","author","date","filesOutput","files","filter","f","diffOutput","push","slice","diff","reverse","error","analyzeCommit","commit","llm","multiLlmService","createModel","prompt","buildCommitAnalysisPrompt","response","invoke","SystemMessage","getCommitAnalysisSystemPrompt","HumanMessage","content","extractContent","parseCommitAnalysis","generatePRDescription","branchName","buildSinglePrompt","getSingleAgentSystemPrompt","title","description","commitSummaries","parseSingleResponse","generateDefaultTitle","createPR","success","formatPRForClipboard","tempFile","Date","now","require","writeFileSync","result","replace","urlMatch","match","undefined","unlinkSync","copyToClipboard","text","JSON","stringify","getPRCreateUrl","httpsUrl","monorepoInfo","monorepoDetector","detectMonorepo","scope","determineScope","join","buildPRDescriptionPrompt","commitsSummary","map","c","i","summary","details","getPRDescriptionSystemPrompt","summaryMatch","detailsMatch","parsePRDescription","titleMatch","indexOf","length","commitsInfo","overviewMatch","changesMatch","technicalMatch","commitsMatch","testingMatch","parts","commitsText","word","charAt","toUpperCase","Array","isArray","first","String"],"mappings":"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"}