@northflare/runner 0.0.11 → 0.0.13
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/utils/config.d.ts +1 -0
- package/dist/utils/config.d.ts.map +1 -1
- package/dist/utils/config.js +13 -2
- package/dist/utils/config.js.map +1 -1
- package/package.json +1 -2
- package/coverage/base.css +0 -224
- package/coverage/block-navigation.js +0 -87
- package/coverage/coverage-final.json +0 -12
- package/coverage/favicon.png +0 -0
- package/coverage/index.html +0 -176
- package/coverage/lib/index.html +0 -116
- package/coverage/lib/preload-script.js.html +0 -964
- package/coverage/prettify.css +0 -1
- package/coverage/prettify.js +0 -2
- package/coverage/sort-arrow-sprite.png +0 -0
- package/coverage/sorter.js +0 -196
- package/coverage/src/collections/index.html +0 -116
- package/coverage/src/collections/runner-messages.ts.html +0 -312
- package/coverage/src/components/claude-manager.ts.html +0 -1290
- package/coverage/src/components/index.html +0 -146
- package/coverage/src/components/message-handler.ts.html +0 -730
- package/coverage/src/components/repository-manager.ts.html +0 -841
- package/coverage/src/index.html +0 -131
- package/coverage/src/index.ts.html +0 -448
- package/coverage/src/runner.ts.html +0 -1239
- package/coverage/src/utils/config.ts.html +0 -780
- package/coverage/src/utils/console.ts.html +0 -121
- package/coverage/src/utils/index.html +0 -161
- package/coverage/src/utils/logger.ts.html +0 -475
- package/coverage/src/utils/status-line.ts.html +0 -445
- package/exceptions.log +0 -24
- package/lib/codex-sdk/src/codex.ts +0 -38
- package/lib/codex-sdk/src/codexOptions.ts +0 -10
- package/lib/codex-sdk/src/events.ts +0 -80
- package/lib/codex-sdk/src/exec.ts +0 -336
- package/lib/codex-sdk/src/index.ts +0 -39
- package/lib/codex-sdk/src/items.ts +0 -127
- package/lib/codex-sdk/src/outputSchemaFile.ts +0 -40
- package/lib/codex-sdk/src/thread.ts +0 -155
- package/lib/codex-sdk/src/threadOptions.ts +0 -18
- package/lib/codex-sdk/src/turnOptions.ts +0 -6
- package/lib/codex-sdk/tests/abort.test.ts +0 -165
- package/lib/codex-sdk/tests/codexExecSpy.ts +0 -37
- package/lib/codex-sdk/tests/responsesProxy.ts +0 -225
- package/lib/codex-sdk/tests/run.test.ts +0 -687
- package/lib/codex-sdk/tests/runStreamed.test.ts +0 -211
- package/lib/codex-sdk/tsconfig.json +0 -24
- package/rejections.log +0 -68
- package/runner.log +0 -488
- package/src/components/claude-sdk-manager.ts +0 -1425
- package/src/components/codex-sdk-manager.ts +0 -1358
- package/src/components/enhanced-repository-manager.ts +0 -823
- package/src/components/message-handler-sse.ts +0 -1097
- package/src/components/repository-manager.ts +0 -337
- package/src/index.ts +0 -168
- package/src/runner-sse.ts +0 -917
- package/src/services/RunnerAPIClient.ts +0 -175
- package/src/services/SSEClient.ts +0 -258
- package/src/types/claude.ts +0 -66
- package/src/types/computer-name.d.ts +0 -4
- package/src/types/index.ts +0 -64
- package/src/types/messages.ts +0 -39
- package/src/types/runner-interface.ts +0 -36
- package/src/utils/StateManager.ts +0 -187
- package/src/utils/config.ts +0 -316
- package/src/utils/console.ts +0 -15
- package/src/utils/debug.ts +0 -18
- package/src/utils/expand-env.ts +0 -22
- package/src/utils/logger.ts +0 -134
- package/src/utils/model.ts +0 -29
- package/src/utils/status-line.ts +0 -122
- package/src/utils/tool-response-sanitizer.ts +0 -160
- package/test-debug.sh +0 -26
- package/tests/retry-strategies.test.ts +0 -410
- package/tests/sdk-integration.test.ts +0 -329
- package/tests/sdk-streaming.test.ts +0 -1180
- package/tests/setup.ts +0 -5
- package/tests/test-claude-manager.ts +0 -120
- package/tests/tool-response-sanitizer.test.ts +0 -63
- package/tsconfig.json +0 -36
- package/vitest.config.ts +0 -27
|
@@ -1,1290 +0,0 @@
|
|
|
1
|
-
<!DOCTYPE html>
|
|
2
|
-
<html lang="en">
|
|
3
|
-
<head>
|
|
4
|
-
<title>Code coverage report for src/components/claude-manager.ts</title>
|
|
5
|
-
<meta charset="utf-8" />
|
|
6
|
-
<link rel="stylesheet" href="../../prettify.css" />
|
|
7
|
-
<link rel="stylesheet" href="../../base.css" />
|
|
8
|
-
<link rel="shortcut icon" type="image/x-icon" href="../../favicon.png" />
|
|
9
|
-
<meta name="viewport" content="width=device-width, initial-scale=1" />
|
|
10
|
-
<style type="text/css">
|
|
11
|
-
.coverage-summary .sorter {
|
|
12
|
-
background-image: url(../../sort-arrow-sprite.png);
|
|
13
|
-
}
|
|
14
|
-
</style>
|
|
15
|
-
</head>
|
|
16
|
-
|
|
17
|
-
<body>
|
|
18
|
-
<div class="wrapper">
|
|
19
|
-
<div class="pad1">
|
|
20
|
-
<h1>
|
|
21
|
-
<a href="../../index.html">All files</a> /
|
|
22
|
-
<a href="index.html">src/components</a> claude-manager.ts
|
|
23
|
-
</h1>
|
|
24
|
-
<div class="clearfix">
|
|
25
|
-
<div class="fl pad1y space-right2">
|
|
26
|
-
<span class="strong">0% </span>
|
|
27
|
-
<span class="quiet">Statements</span>
|
|
28
|
-
<span class="fraction">0/402</span>
|
|
29
|
-
</div>
|
|
30
|
-
|
|
31
|
-
<div class="fl pad1y space-right2">
|
|
32
|
-
<span class="strong">0% </span>
|
|
33
|
-
<span class="quiet">Branches</span>
|
|
34
|
-
<span class="fraction">0/1</span>
|
|
35
|
-
</div>
|
|
36
|
-
|
|
37
|
-
<div class="fl pad1y space-right2">
|
|
38
|
-
<span class="strong">0% </span>
|
|
39
|
-
<span class="quiet">Functions</span>
|
|
40
|
-
<span class="fraction">0/1</span>
|
|
41
|
-
</div>
|
|
42
|
-
|
|
43
|
-
<div class="fl pad1y space-right2">
|
|
44
|
-
<span class="strong">0% </span>
|
|
45
|
-
<span class="quiet">Lines</span>
|
|
46
|
-
<span class="fraction">0/402</span>
|
|
47
|
-
</div>
|
|
48
|
-
</div>
|
|
49
|
-
<p class="quiet">
|
|
50
|
-
Press <em>n</em> or <em>j</em> to go to the next uncovered block,
|
|
51
|
-
<em>b</em>, <em>p</em> or <em>k</em> for the previous block.
|
|
52
|
-
</p>
|
|
53
|
-
<template id="filterTemplate">
|
|
54
|
-
<div class="quiet">
|
|
55
|
-
Filter:
|
|
56
|
-
<input type="search" id="fileSearch" />
|
|
57
|
-
</div>
|
|
58
|
-
</template>
|
|
59
|
-
</div>
|
|
60
|
-
<div class="status-line low"></div>
|
|
61
|
-
<pre><table class="coverage">
|
|
62
|
-
<tr><td class="line-count quiet"><a name='L1'></a><a href='#L1'>1</a>
|
|
63
|
-
<a name='L2'></a><a href='#L2'>2</a>
|
|
64
|
-
<a name='L3'></a><a href='#L3'>3</a>
|
|
65
|
-
<a name='L4'></a><a href='#L4'>4</a>
|
|
66
|
-
<a name='L5'></a><a href='#L5'>5</a>
|
|
67
|
-
<a name='L6'></a><a href='#L6'>6</a>
|
|
68
|
-
<a name='L7'></a><a href='#L7'>7</a>
|
|
69
|
-
<a name='L8'></a><a href='#L8'>8</a>
|
|
70
|
-
<a name='L9'></a><a href='#L9'>9</a>
|
|
71
|
-
<a name='L10'></a><a href='#L10'>10</a>
|
|
72
|
-
<a name='L11'></a><a href='#L11'>11</a>
|
|
73
|
-
<a name='L12'></a><a href='#L12'>12</a>
|
|
74
|
-
<a name='L13'></a><a href='#L13'>13</a>
|
|
75
|
-
<a name='L14'></a><a href='#L14'>14</a>
|
|
76
|
-
<a name='L15'></a><a href='#L15'>15</a>
|
|
77
|
-
<a name='L16'></a><a href='#L16'>16</a>
|
|
78
|
-
<a name='L17'></a><a href='#L17'>17</a>
|
|
79
|
-
<a name='L18'></a><a href='#L18'>18</a>
|
|
80
|
-
<a name='L19'></a><a href='#L19'>19</a>
|
|
81
|
-
<a name='L20'></a><a href='#L20'>20</a>
|
|
82
|
-
<a name='L21'></a><a href='#L21'>21</a>
|
|
83
|
-
<a name='L22'></a><a href='#L22'>22</a>
|
|
84
|
-
<a name='L23'></a><a href='#L23'>23</a>
|
|
85
|
-
<a name='L24'></a><a href='#L24'>24</a>
|
|
86
|
-
<a name='L25'></a><a href='#L25'>25</a>
|
|
87
|
-
<a name='L26'></a><a href='#L26'>26</a>
|
|
88
|
-
<a name='L27'></a><a href='#L27'>27</a>
|
|
89
|
-
<a name='L28'></a><a href='#L28'>28</a>
|
|
90
|
-
<a name='L29'></a><a href='#L29'>29</a>
|
|
91
|
-
<a name='L30'></a><a href='#L30'>30</a>
|
|
92
|
-
<a name='L31'></a><a href='#L31'>31</a>
|
|
93
|
-
<a name='L32'></a><a href='#L32'>32</a>
|
|
94
|
-
<a name='L33'></a><a href='#L33'>33</a>
|
|
95
|
-
<a name='L34'></a><a href='#L34'>34</a>
|
|
96
|
-
<a name='L35'></a><a href='#L35'>35</a>
|
|
97
|
-
<a name='L36'></a><a href='#L36'>36</a>
|
|
98
|
-
<a name='L37'></a><a href='#L37'>37</a>
|
|
99
|
-
<a name='L38'></a><a href='#L38'>38</a>
|
|
100
|
-
<a name='L39'></a><a href='#L39'>39</a>
|
|
101
|
-
<a name='L40'></a><a href='#L40'>40</a>
|
|
102
|
-
<a name='L41'></a><a href='#L41'>41</a>
|
|
103
|
-
<a name='L42'></a><a href='#L42'>42</a>
|
|
104
|
-
<a name='L43'></a><a href='#L43'>43</a>
|
|
105
|
-
<a name='L44'></a><a href='#L44'>44</a>
|
|
106
|
-
<a name='L45'></a><a href='#L45'>45</a>
|
|
107
|
-
<a name='L46'></a><a href='#L46'>46</a>
|
|
108
|
-
<a name='L47'></a><a href='#L47'>47</a>
|
|
109
|
-
<a name='L48'></a><a href='#L48'>48</a>
|
|
110
|
-
<a name='L49'></a><a href='#L49'>49</a>
|
|
111
|
-
<a name='L50'></a><a href='#L50'>50</a>
|
|
112
|
-
<a name='L51'></a><a href='#L51'>51</a>
|
|
113
|
-
<a name='L52'></a><a href='#L52'>52</a>
|
|
114
|
-
<a name='L53'></a><a href='#L53'>53</a>
|
|
115
|
-
<a name='L54'></a><a href='#L54'>54</a>
|
|
116
|
-
<a name='L55'></a><a href='#L55'>55</a>
|
|
117
|
-
<a name='L56'></a><a href='#L56'>56</a>
|
|
118
|
-
<a name='L57'></a><a href='#L57'>57</a>
|
|
119
|
-
<a name='L58'></a><a href='#L58'>58</a>
|
|
120
|
-
<a name='L59'></a><a href='#L59'>59</a>
|
|
121
|
-
<a name='L60'></a><a href='#L60'>60</a>
|
|
122
|
-
<a name='L61'></a><a href='#L61'>61</a>
|
|
123
|
-
<a name='L62'></a><a href='#L62'>62</a>
|
|
124
|
-
<a name='L63'></a><a href='#L63'>63</a>
|
|
125
|
-
<a name='L64'></a><a href='#L64'>64</a>
|
|
126
|
-
<a name='L65'></a><a href='#L65'>65</a>
|
|
127
|
-
<a name='L66'></a><a href='#L66'>66</a>
|
|
128
|
-
<a name='L67'></a><a href='#L67'>67</a>
|
|
129
|
-
<a name='L68'></a><a href='#L68'>68</a>
|
|
130
|
-
<a name='L69'></a><a href='#L69'>69</a>
|
|
131
|
-
<a name='L70'></a><a href='#L70'>70</a>
|
|
132
|
-
<a name='L71'></a><a href='#L71'>71</a>
|
|
133
|
-
<a name='L72'></a><a href='#L72'>72</a>
|
|
134
|
-
<a name='L73'></a><a href='#L73'>73</a>
|
|
135
|
-
<a name='L74'></a><a href='#L74'>74</a>
|
|
136
|
-
<a name='L75'></a><a href='#L75'>75</a>
|
|
137
|
-
<a name='L76'></a><a href='#L76'>76</a>
|
|
138
|
-
<a name='L77'></a><a href='#L77'>77</a>
|
|
139
|
-
<a name='L78'></a><a href='#L78'>78</a>
|
|
140
|
-
<a name='L79'></a><a href='#L79'>79</a>
|
|
141
|
-
<a name='L80'></a><a href='#L80'>80</a>
|
|
142
|
-
<a name='L81'></a><a href='#L81'>81</a>
|
|
143
|
-
<a name='L82'></a><a href='#L82'>82</a>
|
|
144
|
-
<a name='L83'></a><a href='#L83'>83</a>
|
|
145
|
-
<a name='L84'></a><a href='#L84'>84</a>
|
|
146
|
-
<a name='L85'></a><a href='#L85'>85</a>
|
|
147
|
-
<a name='L86'></a><a href='#L86'>86</a>
|
|
148
|
-
<a name='L87'></a><a href='#L87'>87</a>
|
|
149
|
-
<a name='L88'></a><a href='#L88'>88</a>
|
|
150
|
-
<a name='L89'></a><a href='#L89'>89</a>
|
|
151
|
-
<a name='L90'></a><a href='#L90'>90</a>
|
|
152
|
-
<a name='L91'></a><a href='#L91'>91</a>
|
|
153
|
-
<a name='L92'></a><a href='#L92'>92</a>
|
|
154
|
-
<a name='L93'></a><a href='#L93'>93</a>
|
|
155
|
-
<a name='L94'></a><a href='#L94'>94</a>
|
|
156
|
-
<a name='L95'></a><a href='#L95'>95</a>
|
|
157
|
-
<a name='L96'></a><a href='#L96'>96</a>
|
|
158
|
-
<a name='L97'></a><a href='#L97'>97</a>
|
|
159
|
-
<a name='L98'></a><a href='#L98'>98</a>
|
|
160
|
-
<a name='L99'></a><a href='#L99'>99</a>
|
|
161
|
-
<a name='L100'></a><a href='#L100'>100</a>
|
|
162
|
-
<a name='L101'></a><a href='#L101'>101</a>
|
|
163
|
-
<a name='L102'></a><a href='#L102'>102</a>
|
|
164
|
-
<a name='L103'></a><a href='#L103'>103</a>
|
|
165
|
-
<a name='L104'></a><a href='#L104'>104</a>
|
|
166
|
-
<a name='L105'></a><a href='#L105'>105</a>
|
|
167
|
-
<a name='L106'></a><a href='#L106'>106</a>
|
|
168
|
-
<a name='L107'></a><a href='#L107'>107</a>
|
|
169
|
-
<a name='L108'></a><a href='#L108'>108</a>
|
|
170
|
-
<a name='L109'></a><a href='#L109'>109</a>
|
|
171
|
-
<a name='L110'></a><a href='#L110'>110</a>
|
|
172
|
-
<a name='L111'></a><a href='#L111'>111</a>
|
|
173
|
-
<a name='L112'></a><a href='#L112'>112</a>
|
|
174
|
-
<a name='L113'></a><a href='#L113'>113</a>
|
|
175
|
-
<a name='L114'></a><a href='#L114'>114</a>
|
|
176
|
-
<a name='L115'></a><a href='#L115'>115</a>
|
|
177
|
-
<a name='L116'></a><a href='#L116'>116</a>
|
|
178
|
-
<a name='L117'></a><a href='#L117'>117</a>
|
|
179
|
-
<a name='L118'></a><a href='#L118'>118</a>
|
|
180
|
-
<a name='L119'></a><a href='#L119'>119</a>
|
|
181
|
-
<a name='L120'></a><a href='#L120'>120</a>
|
|
182
|
-
<a name='L121'></a><a href='#L121'>121</a>
|
|
183
|
-
<a name='L122'></a><a href='#L122'>122</a>
|
|
184
|
-
<a name='L123'></a><a href='#L123'>123</a>
|
|
185
|
-
<a name='L124'></a><a href='#L124'>124</a>
|
|
186
|
-
<a name='L125'></a><a href='#L125'>125</a>
|
|
187
|
-
<a name='L126'></a><a href='#L126'>126</a>
|
|
188
|
-
<a name='L127'></a><a href='#L127'>127</a>
|
|
189
|
-
<a name='L128'></a><a href='#L128'>128</a>
|
|
190
|
-
<a name='L129'></a><a href='#L129'>129</a>
|
|
191
|
-
<a name='L130'></a><a href='#L130'>130</a>
|
|
192
|
-
<a name='L131'></a><a href='#L131'>131</a>
|
|
193
|
-
<a name='L132'></a><a href='#L132'>132</a>
|
|
194
|
-
<a name='L133'></a><a href='#L133'>133</a>
|
|
195
|
-
<a name='L134'></a><a href='#L134'>134</a>
|
|
196
|
-
<a name='L135'></a><a href='#L135'>135</a>
|
|
197
|
-
<a name='L136'></a><a href='#L136'>136</a>
|
|
198
|
-
<a name='L137'></a><a href='#L137'>137</a>
|
|
199
|
-
<a name='L138'></a><a href='#L138'>138</a>
|
|
200
|
-
<a name='L139'></a><a href='#L139'>139</a>
|
|
201
|
-
<a name='L140'></a><a href='#L140'>140</a>
|
|
202
|
-
<a name='L141'></a><a href='#L141'>141</a>
|
|
203
|
-
<a name='L142'></a><a href='#L142'>142</a>
|
|
204
|
-
<a name='L143'></a><a href='#L143'>143</a>
|
|
205
|
-
<a name='L144'></a><a href='#L144'>144</a>
|
|
206
|
-
<a name='L145'></a><a href='#L145'>145</a>
|
|
207
|
-
<a name='L146'></a><a href='#L146'>146</a>
|
|
208
|
-
<a name='L147'></a><a href='#L147'>147</a>
|
|
209
|
-
<a name='L148'></a><a href='#L148'>148</a>
|
|
210
|
-
<a name='L149'></a><a href='#L149'>149</a>
|
|
211
|
-
<a name='L150'></a><a href='#L150'>150</a>
|
|
212
|
-
<a name='L151'></a><a href='#L151'>151</a>
|
|
213
|
-
<a name='L152'></a><a href='#L152'>152</a>
|
|
214
|
-
<a name='L153'></a><a href='#L153'>153</a>
|
|
215
|
-
<a name='L154'></a><a href='#L154'>154</a>
|
|
216
|
-
<a name='L155'></a><a href='#L155'>155</a>
|
|
217
|
-
<a name='L156'></a><a href='#L156'>156</a>
|
|
218
|
-
<a name='L157'></a><a href='#L157'>157</a>
|
|
219
|
-
<a name='L158'></a><a href='#L158'>158</a>
|
|
220
|
-
<a name='L159'></a><a href='#L159'>159</a>
|
|
221
|
-
<a name='L160'></a><a href='#L160'>160</a>
|
|
222
|
-
<a name='L161'></a><a href='#L161'>161</a>
|
|
223
|
-
<a name='L162'></a><a href='#L162'>162</a>
|
|
224
|
-
<a name='L163'></a><a href='#L163'>163</a>
|
|
225
|
-
<a name='L164'></a><a href='#L164'>164</a>
|
|
226
|
-
<a name='L165'></a><a href='#L165'>165</a>
|
|
227
|
-
<a name='L166'></a><a href='#L166'>166</a>
|
|
228
|
-
<a name='L167'></a><a href='#L167'>167</a>
|
|
229
|
-
<a name='L168'></a><a href='#L168'>168</a>
|
|
230
|
-
<a name='L169'></a><a href='#L169'>169</a>
|
|
231
|
-
<a name='L170'></a><a href='#L170'>170</a>
|
|
232
|
-
<a name='L171'></a><a href='#L171'>171</a>
|
|
233
|
-
<a name='L172'></a><a href='#L172'>172</a>
|
|
234
|
-
<a name='L173'></a><a href='#L173'>173</a>
|
|
235
|
-
<a name='L174'></a><a href='#L174'>174</a>
|
|
236
|
-
<a name='L175'></a><a href='#L175'>175</a>
|
|
237
|
-
<a name='L176'></a><a href='#L176'>176</a>
|
|
238
|
-
<a name='L177'></a><a href='#L177'>177</a>
|
|
239
|
-
<a name='L178'></a><a href='#L178'>178</a>
|
|
240
|
-
<a name='L179'></a><a href='#L179'>179</a>
|
|
241
|
-
<a name='L180'></a><a href='#L180'>180</a>
|
|
242
|
-
<a name='L181'></a><a href='#L181'>181</a>
|
|
243
|
-
<a name='L182'></a><a href='#L182'>182</a>
|
|
244
|
-
<a name='L183'></a><a href='#L183'>183</a>
|
|
245
|
-
<a name='L184'></a><a href='#L184'>184</a>
|
|
246
|
-
<a name='L185'></a><a href='#L185'>185</a>
|
|
247
|
-
<a name='L186'></a><a href='#L186'>186</a>
|
|
248
|
-
<a name='L187'></a><a href='#L187'>187</a>
|
|
249
|
-
<a name='L188'></a><a href='#L188'>188</a>
|
|
250
|
-
<a name='L189'></a><a href='#L189'>189</a>
|
|
251
|
-
<a name='L190'></a><a href='#L190'>190</a>
|
|
252
|
-
<a name='L191'></a><a href='#L191'>191</a>
|
|
253
|
-
<a name='L192'></a><a href='#L192'>192</a>
|
|
254
|
-
<a name='L193'></a><a href='#L193'>193</a>
|
|
255
|
-
<a name='L194'></a><a href='#L194'>194</a>
|
|
256
|
-
<a name='L195'></a><a href='#L195'>195</a>
|
|
257
|
-
<a name='L196'></a><a href='#L196'>196</a>
|
|
258
|
-
<a name='L197'></a><a href='#L197'>197</a>
|
|
259
|
-
<a name='L198'></a><a href='#L198'>198</a>
|
|
260
|
-
<a name='L199'></a><a href='#L199'>199</a>
|
|
261
|
-
<a name='L200'></a><a href='#L200'>200</a>
|
|
262
|
-
<a name='L201'></a><a href='#L201'>201</a>
|
|
263
|
-
<a name='L202'></a><a href='#L202'>202</a>
|
|
264
|
-
<a name='L203'></a><a href='#L203'>203</a>
|
|
265
|
-
<a name='L204'></a><a href='#L204'>204</a>
|
|
266
|
-
<a name='L205'></a><a href='#L205'>205</a>
|
|
267
|
-
<a name='L206'></a><a href='#L206'>206</a>
|
|
268
|
-
<a name='L207'></a><a href='#L207'>207</a>
|
|
269
|
-
<a name='L208'></a><a href='#L208'>208</a>
|
|
270
|
-
<a name='L209'></a><a href='#L209'>209</a>
|
|
271
|
-
<a name='L210'></a><a href='#L210'>210</a>
|
|
272
|
-
<a name='L211'></a><a href='#L211'>211</a>
|
|
273
|
-
<a name='L212'></a><a href='#L212'>212</a>
|
|
274
|
-
<a name='L213'></a><a href='#L213'>213</a>
|
|
275
|
-
<a name='L214'></a><a href='#L214'>214</a>
|
|
276
|
-
<a name='L215'></a><a href='#L215'>215</a>
|
|
277
|
-
<a name='L216'></a><a href='#L216'>216</a>
|
|
278
|
-
<a name='L217'></a><a href='#L217'>217</a>
|
|
279
|
-
<a name='L218'></a><a href='#L218'>218</a>
|
|
280
|
-
<a name='L219'></a><a href='#L219'>219</a>
|
|
281
|
-
<a name='L220'></a><a href='#L220'>220</a>
|
|
282
|
-
<a name='L221'></a><a href='#L221'>221</a>
|
|
283
|
-
<a name='L222'></a><a href='#L222'>222</a>
|
|
284
|
-
<a name='L223'></a><a href='#L223'>223</a>
|
|
285
|
-
<a name='L224'></a><a href='#L224'>224</a>
|
|
286
|
-
<a name='L225'></a><a href='#L225'>225</a>
|
|
287
|
-
<a name='L226'></a><a href='#L226'>226</a>
|
|
288
|
-
<a name='L227'></a><a href='#L227'>227</a>
|
|
289
|
-
<a name='L228'></a><a href='#L228'>228</a>
|
|
290
|
-
<a name='L229'></a><a href='#L229'>229</a>
|
|
291
|
-
<a name='L230'></a><a href='#L230'>230</a>
|
|
292
|
-
<a name='L231'></a><a href='#L231'>231</a>
|
|
293
|
-
<a name='L232'></a><a href='#L232'>232</a>
|
|
294
|
-
<a name='L233'></a><a href='#L233'>233</a>
|
|
295
|
-
<a name='L234'></a><a href='#L234'>234</a>
|
|
296
|
-
<a name='L235'></a><a href='#L235'>235</a>
|
|
297
|
-
<a name='L236'></a><a href='#L236'>236</a>
|
|
298
|
-
<a name='L237'></a><a href='#L237'>237</a>
|
|
299
|
-
<a name='L238'></a><a href='#L238'>238</a>
|
|
300
|
-
<a name='L239'></a><a href='#L239'>239</a>
|
|
301
|
-
<a name='L240'></a><a href='#L240'>240</a>
|
|
302
|
-
<a name='L241'></a><a href='#L241'>241</a>
|
|
303
|
-
<a name='L242'></a><a href='#L242'>242</a>
|
|
304
|
-
<a name='L243'></a><a href='#L243'>243</a>
|
|
305
|
-
<a name='L244'></a><a href='#L244'>244</a>
|
|
306
|
-
<a name='L245'></a><a href='#L245'>245</a>
|
|
307
|
-
<a name='L246'></a><a href='#L246'>246</a>
|
|
308
|
-
<a name='L247'></a><a href='#L247'>247</a>
|
|
309
|
-
<a name='L248'></a><a href='#L248'>248</a>
|
|
310
|
-
<a name='L249'></a><a href='#L249'>249</a>
|
|
311
|
-
<a name='L250'></a><a href='#L250'>250</a>
|
|
312
|
-
<a name='L251'></a><a href='#L251'>251</a>
|
|
313
|
-
<a name='L252'></a><a href='#L252'>252</a>
|
|
314
|
-
<a name='L253'></a><a href='#L253'>253</a>
|
|
315
|
-
<a name='L254'></a><a href='#L254'>254</a>
|
|
316
|
-
<a name='L255'></a><a href='#L255'>255</a>
|
|
317
|
-
<a name='L256'></a><a href='#L256'>256</a>
|
|
318
|
-
<a name='L257'></a><a href='#L257'>257</a>
|
|
319
|
-
<a name='L258'></a><a href='#L258'>258</a>
|
|
320
|
-
<a name='L259'></a><a href='#L259'>259</a>
|
|
321
|
-
<a name='L260'></a><a href='#L260'>260</a>
|
|
322
|
-
<a name='L261'></a><a href='#L261'>261</a>
|
|
323
|
-
<a name='L262'></a><a href='#L262'>262</a>
|
|
324
|
-
<a name='L263'></a><a href='#L263'>263</a>
|
|
325
|
-
<a name='L264'></a><a href='#L264'>264</a>
|
|
326
|
-
<a name='L265'></a><a href='#L265'>265</a>
|
|
327
|
-
<a name='L266'></a><a href='#L266'>266</a>
|
|
328
|
-
<a name='L267'></a><a href='#L267'>267</a>
|
|
329
|
-
<a name='L268'></a><a href='#L268'>268</a>
|
|
330
|
-
<a name='L269'></a><a href='#L269'>269</a>
|
|
331
|
-
<a name='L270'></a><a href='#L270'>270</a>
|
|
332
|
-
<a name='L271'></a><a href='#L271'>271</a>
|
|
333
|
-
<a name='L272'></a><a href='#L272'>272</a>
|
|
334
|
-
<a name='L273'></a><a href='#L273'>273</a>
|
|
335
|
-
<a name='L274'></a><a href='#L274'>274</a>
|
|
336
|
-
<a name='L275'></a><a href='#L275'>275</a>
|
|
337
|
-
<a name='L276'></a><a href='#L276'>276</a>
|
|
338
|
-
<a name='L277'></a><a href='#L277'>277</a>
|
|
339
|
-
<a name='L278'></a><a href='#L278'>278</a>
|
|
340
|
-
<a name='L279'></a><a href='#L279'>279</a>
|
|
341
|
-
<a name='L280'></a><a href='#L280'>280</a>
|
|
342
|
-
<a name='L281'></a><a href='#L281'>281</a>
|
|
343
|
-
<a name='L282'></a><a href='#L282'>282</a>
|
|
344
|
-
<a name='L283'></a><a href='#L283'>283</a>
|
|
345
|
-
<a name='L284'></a><a href='#L284'>284</a>
|
|
346
|
-
<a name='L285'></a><a href='#L285'>285</a>
|
|
347
|
-
<a name='L286'></a><a href='#L286'>286</a>
|
|
348
|
-
<a name='L287'></a><a href='#L287'>287</a>
|
|
349
|
-
<a name='L288'></a><a href='#L288'>288</a>
|
|
350
|
-
<a name='L289'></a><a href='#L289'>289</a>
|
|
351
|
-
<a name='L290'></a><a href='#L290'>290</a>
|
|
352
|
-
<a name='L291'></a><a href='#L291'>291</a>
|
|
353
|
-
<a name='L292'></a><a href='#L292'>292</a>
|
|
354
|
-
<a name='L293'></a><a href='#L293'>293</a>
|
|
355
|
-
<a name='L294'></a><a href='#L294'>294</a>
|
|
356
|
-
<a name='L295'></a><a href='#L295'>295</a>
|
|
357
|
-
<a name='L296'></a><a href='#L296'>296</a>
|
|
358
|
-
<a name='L297'></a><a href='#L297'>297</a>
|
|
359
|
-
<a name='L298'></a><a href='#L298'>298</a>
|
|
360
|
-
<a name='L299'></a><a href='#L299'>299</a>
|
|
361
|
-
<a name='L300'></a><a href='#L300'>300</a>
|
|
362
|
-
<a name='L301'></a><a href='#L301'>301</a>
|
|
363
|
-
<a name='L302'></a><a href='#L302'>302</a>
|
|
364
|
-
<a name='L303'></a><a href='#L303'>303</a>
|
|
365
|
-
<a name='L304'></a><a href='#L304'>304</a>
|
|
366
|
-
<a name='L305'></a><a href='#L305'>305</a>
|
|
367
|
-
<a name='L306'></a><a href='#L306'>306</a>
|
|
368
|
-
<a name='L307'></a><a href='#L307'>307</a>
|
|
369
|
-
<a name='L308'></a><a href='#L308'>308</a>
|
|
370
|
-
<a name='L309'></a><a href='#L309'>309</a>
|
|
371
|
-
<a name='L310'></a><a href='#L310'>310</a>
|
|
372
|
-
<a name='L311'></a><a href='#L311'>311</a>
|
|
373
|
-
<a name='L312'></a><a href='#L312'>312</a>
|
|
374
|
-
<a name='L313'></a><a href='#L313'>313</a>
|
|
375
|
-
<a name='L314'></a><a href='#L314'>314</a>
|
|
376
|
-
<a name='L315'></a><a href='#L315'>315</a>
|
|
377
|
-
<a name='L316'></a><a href='#L316'>316</a>
|
|
378
|
-
<a name='L317'></a><a href='#L317'>317</a>
|
|
379
|
-
<a name='L318'></a><a href='#L318'>318</a>
|
|
380
|
-
<a name='L319'></a><a href='#L319'>319</a>
|
|
381
|
-
<a name='L320'></a><a href='#L320'>320</a>
|
|
382
|
-
<a name='L321'></a><a href='#L321'>321</a>
|
|
383
|
-
<a name='L322'></a><a href='#L322'>322</a>
|
|
384
|
-
<a name='L323'></a><a href='#L323'>323</a>
|
|
385
|
-
<a name='L324'></a><a href='#L324'>324</a>
|
|
386
|
-
<a name='L325'></a><a href='#L325'>325</a>
|
|
387
|
-
<a name='L326'></a><a href='#L326'>326</a>
|
|
388
|
-
<a name='L327'></a><a href='#L327'>327</a>
|
|
389
|
-
<a name='L328'></a><a href='#L328'>328</a>
|
|
390
|
-
<a name='L329'></a><a href='#L329'>329</a>
|
|
391
|
-
<a name='L330'></a><a href='#L330'>330</a>
|
|
392
|
-
<a name='L331'></a><a href='#L331'>331</a>
|
|
393
|
-
<a name='L332'></a><a href='#L332'>332</a>
|
|
394
|
-
<a name='L333'></a><a href='#L333'>333</a>
|
|
395
|
-
<a name='L334'></a><a href='#L334'>334</a>
|
|
396
|
-
<a name='L335'></a><a href='#L335'>335</a>
|
|
397
|
-
<a name='L336'></a><a href='#L336'>336</a>
|
|
398
|
-
<a name='L337'></a><a href='#L337'>337</a>
|
|
399
|
-
<a name='L338'></a><a href='#L338'>338</a>
|
|
400
|
-
<a name='L339'></a><a href='#L339'>339</a>
|
|
401
|
-
<a name='L340'></a><a href='#L340'>340</a>
|
|
402
|
-
<a name='L341'></a><a href='#L341'>341</a>
|
|
403
|
-
<a name='L342'></a><a href='#L342'>342</a>
|
|
404
|
-
<a name='L343'></a><a href='#L343'>343</a>
|
|
405
|
-
<a name='L344'></a><a href='#L344'>344</a>
|
|
406
|
-
<a name='L345'></a><a href='#L345'>345</a>
|
|
407
|
-
<a name='L346'></a><a href='#L346'>346</a>
|
|
408
|
-
<a name='L347'></a><a href='#L347'>347</a>
|
|
409
|
-
<a name='L348'></a><a href='#L348'>348</a>
|
|
410
|
-
<a name='L349'></a><a href='#L349'>349</a>
|
|
411
|
-
<a name='L350'></a><a href='#L350'>350</a>
|
|
412
|
-
<a name='L351'></a><a href='#L351'>351</a>
|
|
413
|
-
<a name='L352'></a><a href='#L352'>352</a>
|
|
414
|
-
<a name='L353'></a><a href='#L353'>353</a>
|
|
415
|
-
<a name='L354'></a><a href='#L354'>354</a>
|
|
416
|
-
<a name='L355'></a><a href='#L355'>355</a>
|
|
417
|
-
<a name='L356'></a><a href='#L356'>356</a>
|
|
418
|
-
<a name='L357'></a><a href='#L357'>357</a>
|
|
419
|
-
<a name='L358'></a><a href='#L358'>358</a>
|
|
420
|
-
<a name='L359'></a><a href='#L359'>359</a>
|
|
421
|
-
<a name='L360'></a><a href='#L360'>360</a>
|
|
422
|
-
<a name='L361'></a><a href='#L361'>361</a>
|
|
423
|
-
<a name='L362'></a><a href='#L362'>362</a>
|
|
424
|
-
<a name='L363'></a><a href='#L363'>363</a>
|
|
425
|
-
<a name='L364'></a><a href='#L364'>364</a>
|
|
426
|
-
<a name='L365'></a><a href='#L365'>365</a>
|
|
427
|
-
<a name='L366'></a><a href='#L366'>366</a>
|
|
428
|
-
<a name='L367'></a><a href='#L367'>367</a>
|
|
429
|
-
<a name='L368'></a><a href='#L368'>368</a>
|
|
430
|
-
<a name='L369'></a><a href='#L369'>369</a>
|
|
431
|
-
<a name='L370'></a><a href='#L370'>370</a>
|
|
432
|
-
<a name='L371'></a><a href='#L371'>371</a>
|
|
433
|
-
<a name='L372'></a><a href='#L372'>372</a>
|
|
434
|
-
<a name='L373'></a><a href='#L373'>373</a>
|
|
435
|
-
<a name='L374'></a><a href='#L374'>374</a>
|
|
436
|
-
<a name='L375'></a><a href='#L375'>375</a>
|
|
437
|
-
<a name='L376'></a><a href='#L376'>376</a>
|
|
438
|
-
<a name='L377'></a><a href='#L377'>377</a>
|
|
439
|
-
<a name='L378'></a><a href='#L378'>378</a>
|
|
440
|
-
<a name='L379'></a><a href='#L379'>379</a>
|
|
441
|
-
<a name='L380'></a><a href='#L380'>380</a>
|
|
442
|
-
<a name='L381'></a><a href='#L381'>381</a>
|
|
443
|
-
<a name='L382'></a><a href='#L382'>382</a>
|
|
444
|
-
<a name='L383'></a><a href='#L383'>383</a>
|
|
445
|
-
<a name='L384'></a><a href='#L384'>384</a>
|
|
446
|
-
<a name='L385'></a><a href='#L385'>385</a>
|
|
447
|
-
<a name='L386'></a><a href='#L386'>386</a>
|
|
448
|
-
<a name='L387'></a><a href='#L387'>387</a>
|
|
449
|
-
<a name='L388'></a><a href='#L388'>388</a>
|
|
450
|
-
<a name='L389'></a><a href='#L389'>389</a>
|
|
451
|
-
<a name='L390'></a><a href='#L390'>390</a>
|
|
452
|
-
<a name='L391'></a><a href='#L391'>391</a>
|
|
453
|
-
<a name='L392'></a><a href='#L392'>392</a>
|
|
454
|
-
<a name='L393'></a><a href='#L393'>393</a>
|
|
455
|
-
<a name='L394'></a><a href='#L394'>394</a>
|
|
456
|
-
<a name='L395'></a><a href='#L395'>395</a>
|
|
457
|
-
<a name='L396'></a><a href='#L396'>396</a>
|
|
458
|
-
<a name='L397'></a><a href='#L397'>397</a>
|
|
459
|
-
<a name='L398'></a><a href='#L398'>398</a>
|
|
460
|
-
<a name='L399'></a><a href='#L399'>399</a>
|
|
461
|
-
<a name='L400'></a><a href='#L400'>400</a>
|
|
462
|
-
<a name='L401'></a><a href='#L401'>401</a>
|
|
463
|
-
<a name='L402'></a><a href='#L402'>402</a></td><td class="line-coverage quiet"><span class="cline-any cline-no"> </span>
|
|
464
|
-
<span class="cline-any cline-no"> </span>
|
|
465
|
-
<span class="cline-any cline-no"> </span>
|
|
466
|
-
<span class="cline-any cline-no"> </span>
|
|
467
|
-
<span class="cline-any cline-no"> </span>
|
|
468
|
-
<span class="cline-any cline-no"> </span>
|
|
469
|
-
<span class="cline-any cline-no"> </span>
|
|
470
|
-
<span class="cline-any cline-no"> </span>
|
|
471
|
-
<span class="cline-any cline-no"> </span>
|
|
472
|
-
<span class="cline-any cline-no"> </span>
|
|
473
|
-
<span class="cline-any cline-no"> </span>
|
|
474
|
-
<span class="cline-any cline-no"> </span>
|
|
475
|
-
<span class="cline-any cline-no"> </span>
|
|
476
|
-
<span class="cline-any cline-no"> </span>
|
|
477
|
-
<span class="cline-any cline-no"> </span>
|
|
478
|
-
<span class="cline-any cline-no"> </span>
|
|
479
|
-
<span class="cline-any cline-no"> </span>
|
|
480
|
-
<span class="cline-any cline-no"> </span>
|
|
481
|
-
<span class="cline-any cline-no"> </span>
|
|
482
|
-
<span class="cline-any cline-no"> </span>
|
|
483
|
-
<span class="cline-any cline-no"> </span>
|
|
484
|
-
<span class="cline-any cline-no"> </span>
|
|
485
|
-
<span class="cline-any cline-no"> </span>
|
|
486
|
-
<span class="cline-any cline-no"> </span>
|
|
487
|
-
<span class="cline-any cline-no"> </span>
|
|
488
|
-
<span class="cline-any cline-no"> </span>
|
|
489
|
-
<span class="cline-any cline-no"> </span>
|
|
490
|
-
<span class="cline-any cline-no"> </span>
|
|
491
|
-
<span class="cline-any cline-no"> </span>
|
|
492
|
-
<span class="cline-any cline-no"> </span>
|
|
493
|
-
<span class="cline-any cline-no"> </span>
|
|
494
|
-
<span class="cline-any cline-no"> </span>
|
|
495
|
-
<span class="cline-any cline-no"> </span>
|
|
496
|
-
<span class="cline-any cline-no"> </span>
|
|
497
|
-
<span class="cline-any cline-no"> </span>
|
|
498
|
-
<span class="cline-any cline-no"> </span>
|
|
499
|
-
<span class="cline-any cline-no"> </span>
|
|
500
|
-
<span class="cline-any cline-no"> </span>
|
|
501
|
-
<span class="cline-any cline-no"> </span>
|
|
502
|
-
<span class="cline-any cline-no"> </span>
|
|
503
|
-
<span class="cline-any cline-no"> </span>
|
|
504
|
-
<span class="cline-any cline-no"> </span>
|
|
505
|
-
<span class="cline-any cline-no"> </span>
|
|
506
|
-
<span class="cline-any cline-no"> </span>
|
|
507
|
-
<span class="cline-any cline-no"> </span>
|
|
508
|
-
<span class="cline-any cline-no"> </span>
|
|
509
|
-
<span class="cline-any cline-no"> </span>
|
|
510
|
-
<span class="cline-any cline-no"> </span>
|
|
511
|
-
<span class="cline-any cline-no"> </span>
|
|
512
|
-
<span class="cline-any cline-no"> </span>
|
|
513
|
-
<span class="cline-any cline-no"> </span>
|
|
514
|
-
<span class="cline-any cline-no"> </span>
|
|
515
|
-
<span class="cline-any cline-no"> </span>
|
|
516
|
-
<span class="cline-any cline-no"> </span>
|
|
517
|
-
<span class="cline-any cline-no"> </span>
|
|
518
|
-
<span class="cline-any cline-no"> </span>
|
|
519
|
-
<span class="cline-any cline-no"> </span>
|
|
520
|
-
<span class="cline-any cline-no"> </span>
|
|
521
|
-
<span class="cline-any cline-no"> </span>
|
|
522
|
-
<span class="cline-any cline-no"> </span>
|
|
523
|
-
<span class="cline-any cline-no"> </span>
|
|
524
|
-
<span class="cline-any cline-no"> </span>
|
|
525
|
-
<span class="cline-any cline-no"> </span>
|
|
526
|
-
<span class="cline-any cline-no"> </span>
|
|
527
|
-
<span class="cline-any cline-no"> </span>
|
|
528
|
-
<span class="cline-any cline-no"> </span>
|
|
529
|
-
<span class="cline-any cline-no"> </span>
|
|
530
|
-
<span class="cline-any cline-no"> </span>
|
|
531
|
-
<span class="cline-any cline-no"> </span>
|
|
532
|
-
<span class="cline-any cline-no"> </span>
|
|
533
|
-
<span class="cline-any cline-no"> </span>
|
|
534
|
-
<span class="cline-any cline-no"> </span>
|
|
535
|
-
<span class="cline-any cline-no"> </span>
|
|
536
|
-
<span class="cline-any cline-no"> </span>
|
|
537
|
-
<span class="cline-any cline-no"> </span>
|
|
538
|
-
<span class="cline-any cline-no"> </span>
|
|
539
|
-
<span class="cline-any cline-no"> </span>
|
|
540
|
-
<span class="cline-any cline-no"> </span>
|
|
541
|
-
<span class="cline-any cline-no"> </span>
|
|
542
|
-
<span class="cline-any cline-no"> </span>
|
|
543
|
-
<span class="cline-any cline-no"> </span>
|
|
544
|
-
<span class="cline-any cline-no"> </span>
|
|
545
|
-
<span class="cline-any cline-no"> </span>
|
|
546
|
-
<span class="cline-any cline-no"> </span>
|
|
547
|
-
<span class="cline-any cline-no"> </span>
|
|
548
|
-
<span class="cline-any cline-no"> </span>
|
|
549
|
-
<span class="cline-any cline-no"> </span>
|
|
550
|
-
<span class="cline-any cline-no"> </span>
|
|
551
|
-
<span class="cline-any cline-no"> </span>
|
|
552
|
-
<span class="cline-any cline-no"> </span>
|
|
553
|
-
<span class="cline-any cline-no"> </span>
|
|
554
|
-
<span class="cline-any cline-no"> </span>
|
|
555
|
-
<span class="cline-any cline-no"> </span>
|
|
556
|
-
<span class="cline-any cline-no"> </span>
|
|
557
|
-
<span class="cline-any cline-no"> </span>
|
|
558
|
-
<span class="cline-any cline-no"> </span>
|
|
559
|
-
<span class="cline-any cline-no"> </span>
|
|
560
|
-
<span class="cline-any cline-no"> </span>
|
|
561
|
-
<span class="cline-any cline-no"> </span>
|
|
562
|
-
<span class="cline-any cline-no"> </span>
|
|
563
|
-
<span class="cline-any cline-no"> </span>
|
|
564
|
-
<span class="cline-any cline-no"> </span>
|
|
565
|
-
<span class="cline-any cline-no"> </span>
|
|
566
|
-
<span class="cline-any cline-no"> </span>
|
|
567
|
-
<span class="cline-any cline-no"> </span>
|
|
568
|
-
<span class="cline-any cline-no"> </span>
|
|
569
|
-
<span class="cline-any cline-no"> </span>
|
|
570
|
-
<span class="cline-any cline-no"> </span>
|
|
571
|
-
<span class="cline-any cline-no"> </span>
|
|
572
|
-
<span class="cline-any cline-no"> </span>
|
|
573
|
-
<span class="cline-any cline-no"> </span>
|
|
574
|
-
<span class="cline-any cline-no"> </span>
|
|
575
|
-
<span class="cline-any cline-no"> </span>
|
|
576
|
-
<span class="cline-any cline-no"> </span>
|
|
577
|
-
<span class="cline-any cline-no"> </span>
|
|
578
|
-
<span class="cline-any cline-no"> </span>
|
|
579
|
-
<span class="cline-any cline-no"> </span>
|
|
580
|
-
<span class="cline-any cline-no"> </span>
|
|
581
|
-
<span class="cline-any cline-no"> </span>
|
|
582
|
-
<span class="cline-any cline-no"> </span>
|
|
583
|
-
<span class="cline-any cline-no"> </span>
|
|
584
|
-
<span class="cline-any cline-no"> </span>
|
|
585
|
-
<span class="cline-any cline-no"> </span>
|
|
586
|
-
<span class="cline-any cline-no"> </span>
|
|
587
|
-
<span class="cline-any cline-no"> </span>
|
|
588
|
-
<span class="cline-any cline-no"> </span>
|
|
589
|
-
<span class="cline-any cline-no"> </span>
|
|
590
|
-
<span class="cline-any cline-no"> </span>
|
|
591
|
-
<span class="cline-any cline-no"> </span>
|
|
592
|
-
<span class="cline-any cline-no"> </span>
|
|
593
|
-
<span class="cline-any cline-no"> </span>
|
|
594
|
-
<span class="cline-any cline-no"> </span>
|
|
595
|
-
<span class="cline-any cline-no"> </span>
|
|
596
|
-
<span class="cline-any cline-no"> </span>
|
|
597
|
-
<span class="cline-any cline-no"> </span>
|
|
598
|
-
<span class="cline-any cline-no"> </span>
|
|
599
|
-
<span class="cline-any cline-no"> </span>
|
|
600
|
-
<span class="cline-any cline-no"> </span>
|
|
601
|
-
<span class="cline-any cline-no"> </span>
|
|
602
|
-
<span class="cline-any cline-no"> </span>
|
|
603
|
-
<span class="cline-any cline-no"> </span>
|
|
604
|
-
<span class="cline-any cline-no"> </span>
|
|
605
|
-
<span class="cline-any cline-no"> </span>
|
|
606
|
-
<span class="cline-any cline-no"> </span>
|
|
607
|
-
<span class="cline-any cline-no"> </span>
|
|
608
|
-
<span class="cline-any cline-no"> </span>
|
|
609
|
-
<span class="cline-any cline-no"> </span>
|
|
610
|
-
<span class="cline-any cline-no"> </span>
|
|
611
|
-
<span class="cline-any cline-no"> </span>
|
|
612
|
-
<span class="cline-any cline-no"> </span>
|
|
613
|
-
<span class="cline-any cline-no"> </span>
|
|
614
|
-
<span class="cline-any cline-no"> </span>
|
|
615
|
-
<span class="cline-any cline-no"> </span>
|
|
616
|
-
<span class="cline-any cline-no"> </span>
|
|
617
|
-
<span class="cline-any cline-no"> </span>
|
|
618
|
-
<span class="cline-any cline-no"> </span>
|
|
619
|
-
<span class="cline-any cline-no"> </span>
|
|
620
|
-
<span class="cline-any cline-no"> </span>
|
|
621
|
-
<span class="cline-any cline-no"> </span>
|
|
622
|
-
<span class="cline-any cline-no"> </span>
|
|
623
|
-
<span class="cline-any cline-no"> </span>
|
|
624
|
-
<span class="cline-any cline-no"> </span>
|
|
625
|
-
<span class="cline-any cline-no"> </span>
|
|
626
|
-
<span class="cline-any cline-no"> </span>
|
|
627
|
-
<span class="cline-any cline-no"> </span>
|
|
628
|
-
<span class="cline-any cline-no"> </span>
|
|
629
|
-
<span class="cline-any cline-no"> </span>
|
|
630
|
-
<span class="cline-any cline-no"> </span>
|
|
631
|
-
<span class="cline-any cline-no"> </span>
|
|
632
|
-
<span class="cline-any cline-no"> </span>
|
|
633
|
-
<span class="cline-any cline-no"> </span>
|
|
634
|
-
<span class="cline-any cline-no"> </span>
|
|
635
|
-
<span class="cline-any cline-no"> </span>
|
|
636
|
-
<span class="cline-any cline-no"> </span>
|
|
637
|
-
<span class="cline-any cline-no"> </span>
|
|
638
|
-
<span class="cline-any cline-no"> </span>
|
|
639
|
-
<span class="cline-any cline-no"> </span>
|
|
640
|
-
<span class="cline-any cline-no"> </span>
|
|
641
|
-
<span class="cline-any cline-no"> </span>
|
|
642
|
-
<span class="cline-any cline-no"> </span>
|
|
643
|
-
<span class="cline-any cline-no"> </span>
|
|
644
|
-
<span class="cline-any cline-no"> </span>
|
|
645
|
-
<span class="cline-any cline-no"> </span>
|
|
646
|
-
<span class="cline-any cline-no"> </span>
|
|
647
|
-
<span class="cline-any cline-no"> </span>
|
|
648
|
-
<span class="cline-any cline-no"> </span>
|
|
649
|
-
<span class="cline-any cline-no"> </span>
|
|
650
|
-
<span class="cline-any cline-no"> </span>
|
|
651
|
-
<span class="cline-any cline-no"> </span>
|
|
652
|
-
<span class="cline-any cline-no"> </span>
|
|
653
|
-
<span class="cline-any cline-no"> </span>
|
|
654
|
-
<span class="cline-any cline-no"> </span>
|
|
655
|
-
<span class="cline-any cline-no"> </span>
|
|
656
|
-
<span class="cline-any cline-no"> </span>
|
|
657
|
-
<span class="cline-any cline-no"> </span>
|
|
658
|
-
<span class="cline-any cline-no"> </span>
|
|
659
|
-
<span class="cline-any cline-no"> </span>
|
|
660
|
-
<span class="cline-any cline-no"> </span>
|
|
661
|
-
<span class="cline-any cline-no"> </span>
|
|
662
|
-
<span class="cline-any cline-no"> </span>
|
|
663
|
-
<span class="cline-any cline-no"> </span>
|
|
664
|
-
<span class="cline-any cline-no"> </span>
|
|
665
|
-
<span class="cline-any cline-no"> </span>
|
|
666
|
-
<span class="cline-any cline-no"> </span>
|
|
667
|
-
<span class="cline-any cline-no"> </span>
|
|
668
|
-
<span class="cline-any cline-no"> </span>
|
|
669
|
-
<span class="cline-any cline-no"> </span>
|
|
670
|
-
<span class="cline-any cline-no"> </span>
|
|
671
|
-
<span class="cline-any cline-no"> </span>
|
|
672
|
-
<span class="cline-any cline-no"> </span>
|
|
673
|
-
<span class="cline-any cline-no"> </span>
|
|
674
|
-
<span class="cline-any cline-no"> </span>
|
|
675
|
-
<span class="cline-any cline-no"> </span>
|
|
676
|
-
<span class="cline-any cline-no"> </span>
|
|
677
|
-
<span class="cline-any cline-no"> </span>
|
|
678
|
-
<span class="cline-any cline-no"> </span>
|
|
679
|
-
<span class="cline-any cline-no"> </span>
|
|
680
|
-
<span class="cline-any cline-no"> </span>
|
|
681
|
-
<span class="cline-any cline-no"> </span>
|
|
682
|
-
<span class="cline-any cline-no"> </span>
|
|
683
|
-
<span class="cline-any cline-no"> </span>
|
|
684
|
-
<span class="cline-any cline-no"> </span>
|
|
685
|
-
<span class="cline-any cline-no"> </span>
|
|
686
|
-
<span class="cline-any cline-no"> </span>
|
|
687
|
-
<span class="cline-any cline-no"> </span>
|
|
688
|
-
<span class="cline-any cline-no"> </span>
|
|
689
|
-
<span class="cline-any cline-no"> </span>
|
|
690
|
-
<span class="cline-any cline-no"> </span>
|
|
691
|
-
<span class="cline-any cline-no"> </span>
|
|
692
|
-
<span class="cline-any cline-no"> </span>
|
|
693
|
-
<span class="cline-any cline-no"> </span>
|
|
694
|
-
<span class="cline-any cline-no"> </span>
|
|
695
|
-
<span class="cline-any cline-no"> </span>
|
|
696
|
-
<span class="cline-any cline-no"> </span>
|
|
697
|
-
<span class="cline-any cline-no"> </span>
|
|
698
|
-
<span class="cline-any cline-no"> </span>
|
|
699
|
-
<span class="cline-any cline-no"> </span>
|
|
700
|
-
<span class="cline-any cline-no"> </span>
|
|
701
|
-
<span class="cline-any cline-no"> </span>
|
|
702
|
-
<span class="cline-any cline-no"> </span>
|
|
703
|
-
<span class="cline-any cline-no"> </span>
|
|
704
|
-
<span class="cline-any cline-no"> </span>
|
|
705
|
-
<span class="cline-any cline-no"> </span>
|
|
706
|
-
<span class="cline-any cline-no"> </span>
|
|
707
|
-
<span class="cline-any cline-no"> </span>
|
|
708
|
-
<span class="cline-any cline-no"> </span>
|
|
709
|
-
<span class="cline-any cline-no"> </span>
|
|
710
|
-
<span class="cline-any cline-no"> </span>
|
|
711
|
-
<span class="cline-any cline-no"> </span>
|
|
712
|
-
<span class="cline-any cline-no"> </span>
|
|
713
|
-
<span class="cline-any cline-no"> </span>
|
|
714
|
-
<span class="cline-any cline-no"> </span>
|
|
715
|
-
<span class="cline-any cline-no"> </span>
|
|
716
|
-
<span class="cline-any cline-no"> </span>
|
|
717
|
-
<span class="cline-any cline-no"> </span>
|
|
718
|
-
<span class="cline-any cline-no"> </span>
|
|
719
|
-
<span class="cline-any cline-no"> </span>
|
|
720
|
-
<span class="cline-any cline-no"> </span>
|
|
721
|
-
<span class="cline-any cline-no"> </span>
|
|
722
|
-
<span class="cline-any cline-no"> </span>
|
|
723
|
-
<span class="cline-any cline-no"> </span>
|
|
724
|
-
<span class="cline-any cline-no"> </span>
|
|
725
|
-
<span class="cline-any cline-no"> </span>
|
|
726
|
-
<span class="cline-any cline-no"> </span>
|
|
727
|
-
<span class="cline-any cline-no"> </span>
|
|
728
|
-
<span class="cline-any cline-no"> </span>
|
|
729
|
-
<span class="cline-any cline-no"> </span>
|
|
730
|
-
<span class="cline-any cline-no"> </span>
|
|
731
|
-
<span class="cline-any cline-no"> </span>
|
|
732
|
-
<span class="cline-any cline-no"> </span>
|
|
733
|
-
<span class="cline-any cline-no"> </span>
|
|
734
|
-
<span class="cline-any cline-no"> </span>
|
|
735
|
-
<span class="cline-any cline-no"> </span>
|
|
736
|
-
<span class="cline-any cline-no"> </span>
|
|
737
|
-
<span class="cline-any cline-no"> </span>
|
|
738
|
-
<span class="cline-any cline-no"> </span>
|
|
739
|
-
<span class="cline-any cline-no"> </span>
|
|
740
|
-
<span class="cline-any cline-no"> </span>
|
|
741
|
-
<span class="cline-any cline-no"> </span>
|
|
742
|
-
<span class="cline-any cline-no"> </span>
|
|
743
|
-
<span class="cline-any cline-no"> </span>
|
|
744
|
-
<span class="cline-any cline-no"> </span>
|
|
745
|
-
<span class="cline-any cline-no"> </span>
|
|
746
|
-
<span class="cline-any cline-no"> </span>
|
|
747
|
-
<span class="cline-any cline-no"> </span>
|
|
748
|
-
<span class="cline-any cline-no"> </span>
|
|
749
|
-
<span class="cline-any cline-no"> </span>
|
|
750
|
-
<span class="cline-any cline-no"> </span>
|
|
751
|
-
<span class="cline-any cline-no"> </span>
|
|
752
|
-
<span class="cline-any cline-no"> </span>
|
|
753
|
-
<span class="cline-any cline-no"> </span>
|
|
754
|
-
<span class="cline-any cline-no"> </span>
|
|
755
|
-
<span class="cline-any cline-no"> </span>
|
|
756
|
-
<span class="cline-any cline-no"> </span>
|
|
757
|
-
<span class="cline-any cline-no"> </span>
|
|
758
|
-
<span class="cline-any cline-no"> </span>
|
|
759
|
-
<span class="cline-any cline-no"> </span>
|
|
760
|
-
<span class="cline-any cline-no"> </span>
|
|
761
|
-
<span class="cline-any cline-no"> </span>
|
|
762
|
-
<span class="cline-any cline-no"> </span>
|
|
763
|
-
<span class="cline-any cline-no"> </span>
|
|
764
|
-
<span class="cline-any cline-no"> </span>
|
|
765
|
-
<span class="cline-any cline-no"> </span>
|
|
766
|
-
<span class="cline-any cline-no"> </span>
|
|
767
|
-
<span class="cline-any cline-no"> </span>
|
|
768
|
-
<span class="cline-any cline-no"> </span>
|
|
769
|
-
<span class="cline-any cline-no"> </span>
|
|
770
|
-
<span class="cline-any cline-no"> </span>
|
|
771
|
-
<span class="cline-any cline-no"> </span>
|
|
772
|
-
<span class="cline-any cline-no"> </span>
|
|
773
|
-
<span class="cline-any cline-no"> </span>
|
|
774
|
-
<span class="cline-any cline-no"> </span>
|
|
775
|
-
<span class="cline-any cline-no"> </span>
|
|
776
|
-
<span class="cline-any cline-no"> </span>
|
|
777
|
-
<span class="cline-any cline-no"> </span>
|
|
778
|
-
<span class="cline-any cline-no"> </span>
|
|
779
|
-
<span class="cline-any cline-no"> </span>
|
|
780
|
-
<span class="cline-any cline-no"> </span>
|
|
781
|
-
<span class="cline-any cline-no"> </span>
|
|
782
|
-
<span class="cline-any cline-no"> </span>
|
|
783
|
-
<span class="cline-any cline-no"> </span>
|
|
784
|
-
<span class="cline-any cline-no"> </span>
|
|
785
|
-
<span class="cline-any cline-no"> </span>
|
|
786
|
-
<span class="cline-any cline-no"> </span>
|
|
787
|
-
<span class="cline-any cline-no"> </span>
|
|
788
|
-
<span class="cline-any cline-no"> </span>
|
|
789
|
-
<span class="cline-any cline-no"> </span>
|
|
790
|
-
<span class="cline-any cline-no"> </span>
|
|
791
|
-
<span class="cline-any cline-no"> </span>
|
|
792
|
-
<span class="cline-any cline-no"> </span>
|
|
793
|
-
<span class="cline-any cline-no"> </span>
|
|
794
|
-
<span class="cline-any cline-no"> </span>
|
|
795
|
-
<span class="cline-any cline-no"> </span>
|
|
796
|
-
<span class="cline-any cline-no"> </span>
|
|
797
|
-
<span class="cline-any cline-no"> </span>
|
|
798
|
-
<span class="cline-any cline-no"> </span>
|
|
799
|
-
<span class="cline-any cline-no"> </span>
|
|
800
|
-
<span class="cline-any cline-no"> </span>
|
|
801
|
-
<span class="cline-any cline-no"> </span>
|
|
802
|
-
<span class="cline-any cline-no"> </span>
|
|
803
|
-
<span class="cline-any cline-no"> </span>
|
|
804
|
-
<span class="cline-any cline-no"> </span>
|
|
805
|
-
<span class="cline-any cline-no"> </span>
|
|
806
|
-
<span class="cline-any cline-no"> </span>
|
|
807
|
-
<span class="cline-any cline-no"> </span>
|
|
808
|
-
<span class="cline-any cline-no"> </span>
|
|
809
|
-
<span class="cline-any cline-no"> </span>
|
|
810
|
-
<span class="cline-any cline-no"> </span>
|
|
811
|
-
<span class="cline-any cline-no"> </span>
|
|
812
|
-
<span class="cline-any cline-no"> </span>
|
|
813
|
-
<span class="cline-any cline-no"> </span>
|
|
814
|
-
<span class="cline-any cline-no"> </span>
|
|
815
|
-
<span class="cline-any cline-no"> </span>
|
|
816
|
-
<span class="cline-any cline-no"> </span>
|
|
817
|
-
<span class="cline-any cline-no"> </span>
|
|
818
|
-
<span class="cline-any cline-no"> </span>
|
|
819
|
-
<span class="cline-any cline-no"> </span>
|
|
820
|
-
<span class="cline-any cline-no"> </span>
|
|
821
|
-
<span class="cline-any cline-no"> </span>
|
|
822
|
-
<span class="cline-any cline-no"> </span>
|
|
823
|
-
<span class="cline-any cline-no"> </span>
|
|
824
|
-
<span class="cline-any cline-no"> </span>
|
|
825
|
-
<span class="cline-any cline-no"> </span>
|
|
826
|
-
<span class="cline-any cline-no"> </span>
|
|
827
|
-
<span class="cline-any cline-no"> </span>
|
|
828
|
-
<span class="cline-any cline-no"> </span>
|
|
829
|
-
<span class="cline-any cline-no"> </span>
|
|
830
|
-
<span class="cline-any cline-no"> </span>
|
|
831
|
-
<span class="cline-any cline-no"> </span>
|
|
832
|
-
<span class="cline-any cline-no"> </span>
|
|
833
|
-
<span class="cline-any cline-no"> </span>
|
|
834
|
-
<span class="cline-any cline-no"> </span>
|
|
835
|
-
<span class="cline-any cline-no"> </span>
|
|
836
|
-
<span class="cline-any cline-no"> </span>
|
|
837
|
-
<span class="cline-any cline-no"> </span>
|
|
838
|
-
<span class="cline-any cline-no"> </span>
|
|
839
|
-
<span class="cline-any cline-no"> </span>
|
|
840
|
-
<span class="cline-any cline-no"> </span>
|
|
841
|
-
<span class="cline-any cline-no"> </span>
|
|
842
|
-
<span class="cline-any cline-no"> </span>
|
|
843
|
-
<span class="cline-any cline-no"> </span>
|
|
844
|
-
<span class="cline-any cline-no"> </span>
|
|
845
|
-
<span class="cline-any cline-no"> </span>
|
|
846
|
-
<span class="cline-any cline-no"> </span>
|
|
847
|
-
<span class="cline-any cline-no"> </span>
|
|
848
|
-
<span class="cline-any cline-no"> </span>
|
|
849
|
-
<span class="cline-any cline-no"> </span>
|
|
850
|
-
<span class="cline-any cline-no"> </span>
|
|
851
|
-
<span class="cline-any cline-no"> </span>
|
|
852
|
-
<span class="cline-any cline-no"> </span>
|
|
853
|
-
<span class="cline-any cline-no"> </span>
|
|
854
|
-
<span class="cline-any cline-no"> </span>
|
|
855
|
-
<span class="cline-any cline-no"> </span>
|
|
856
|
-
<span class="cline-any cline-no"> </span>
|
|
857
|
-
<span class="cline-any cline-no"> </span>
|
|
858
|
-
<span class="cline-any cline-no"> </span>
|
|
859
|
-
<span class="cline-any cline-no"> </span>
|
|
860
|
-
<span class="cline-any cline-no"> </span>
|
|
861
|
-
<span class="cline-any cline-no"> </span>
|
|
862
|
-
<span class="cline-any cline-no"> </span>
|
|
863
|
-
<span class="cline-any cline-no"> </span>
|
|
864
|
-
<span class="cline-any cline-no"> </span></td><td class="text"><pre class="prettyprint lang-js"><span class="cstat-no" title="statement not covered" >/**<span class="fstat-no" title="function not covered" ><span class="branch-0 cbranch-no" title="branch not covered" ></span></span></span>
|
|
865
|
-
<span class="cstat-no" title="statement not covered" > * ClaudeManager - Manages Claude conversations using claude-code-sdk-ts</span>
|
|
866
|
-
<span class="cstat-no" title="statement not covered" > * </span>
|
|
867
|
-
<span class="cstat-no" title="statement not covered" > * This component handles stateful conversation lifecycle management, maintaining</span>
|
|
868
|
-
<span class="cstat-no" title="statement not covered" > * persistent conversation instances indexed by taskId. It integrates with the</span>
|
|
869
|
-
<span class="cstat-no" title="statement not covered" > * Claude SDK to manage sessions, handle MCP server configurations, and coordinate</span>
|
|
870
|
-
<span class="cstat-no" title="statement not covered" > * with the orchestrator for authentication and notifications.</span>
|
|
871
|
-
<span class="cstat-no" title="statement not covered" > */</span>
|
|
872
|
-
<span class="cstat-no" title="statement not covered" ></span>
|
|
873
|
-
<span class="cstat-no" title="statement not covered" >import { claude, Message as SDKMessage } from "@botanicastudios/claude-code-sdk-ts";</span>
|
|
874
|
-
<span class="cstat-no" title="statement not covered" >import { RunnerApp } from "../runner";</span>
|
|
875
|
-
<span class="cstat-no" title="statement not covered" >import { RepositoryManager } from "./repository-manager";</span>
|
|
876
|
-
<span class="cstat-no" title="statement not covered" >import { ConversationConfig, Message } from "../types";</span>
|
|
877
|
-
<span class="cstat-no" title="statement not covered" >import { statusLineManager } from "../utils/status-line";</span>
|
|
878
|
-
<span class="cstat-no" title="statement not covered" >import { console } from "../utils/console";</span>
|
|
879
|
-
<span class="cstat-no" title="statement not covered" ></span>
|
|
880
|
-
<span class="cstat-no" title="statement not covered" >export class ClaudeManager {</span>
|
|
881
|
-
<span class="cstat-no" title="statement not covered" > private runner: RunnerApp;</span>
|
|
882
|
-
<span class="cstat-no" title="statement not covered" > private repositoryManager: RepositoryManager;</span>
|
|
883
|
-
<span class="cstat-no" title="statement not covered" ></span>
|
|
884
|
-
<span class="cstat-no" title="statement not covered" > constructor(runner: RunnerApp, repositoryManager: RepositoryManager) {</span>
|
|
885
|
-
<span class="cstat-no" title="statement not covered" > this.runner = runner;</span>
|
|
886
|
-
<span class="cstat-no" title="statement not covered" > this.repositoryManager = repositoryManager;</span>
|
|
887
|
-
<span class="cstat-no" title="statement not covered" > </span>
|
|
888
|
-
<span class="cstat-no" title="statement not covered" > // Note: MCP host configuration is passed from orchestrator</span>
|
|
889
|
-
<span class="cstat-no" title="statement not covered" > // Runner does not define its own MCP tools</span>
|
|
890
|
-
<span class="cstat-no" title="statement not covered" > this.setupInternalMcpServer();</span>
|
|
891
|
-
<span class="cstat-no" title="statement not covered" > }</span>
|
|
892
|
-
<span class="cstat-no" title="statement not covered" ></span>
|
|
893
|
-
<span class="cstat-no" title="statement not covered" > private setupInternalMcpServer(): void {</span>
|
|
894
|
-
<span class="cstat-no" title="statement not covered" > // Runner does not define its own MCP tools</span>
|
|
895
|
-
<span class="cstat-no" title="statement not covered" > // All MCP tool configuration is passed from orchestrator in conversation config</span>
|
|
896
|
-
<span class="cstat-no" title="statement not covered" > }</span>
|
|
897
|
-
<span class="cstat-no" title="statement not covered" ></span>
|
|
898
|
-
<span class="cstat-no" title="statement not covered" > async startConversation(</span>
|
|
899
|
-
<span class="cstat-no" title="statement not covered" > taskId: string,</span>
|
|
900
|
-
<span class="cstat-no" title="statement not covered" > config: ConversationConfig,</span>
|
|
901
|
-
<span class="cstat-no" title="statement not covered" > initialMessages: Message[]</span>
|
|
902
|
-
<span class="cstat-no" title="statement not covered" > ): Promise<void> {</span>
|
|
903
|
-
<span class="cstat-no" title="statement not covered" > const context = this.runner.getConversationContext(taskId);</span>
|
|
904
|
-
<span class="cstat-no" title="statement not covered" > const workspaceId = context.workspaceId;</span>
|
|
905
|
-
<span class="cstat-no" title="statement not covered" ></span>
|
|
906
|
-
<span class="cstat-no" title="statement not covered" > // Checkout repository if specified</span>
|
|
907
|
-
<span class="cstat-no" title="statement not covered" > let workspacePath: string;</span>
|
|
908
|
-
<span class="cstat-no" title="statement not covered" > if (config.repository) {</span>
|
|
909
|
-
<span class="cstat-no" title="statement not covered" > workspacePath = await this.repositoryManager.checkoutRepository(</span>
|
|
910
|
-
<span class="cstat-no" title="statement not covered" > workspaceId,</span>
|
|
911
|
-
<span class="cstat-no" title="statement not covered" > config.repository.url,</span>
|
|
912
|
-
<span class="cstat-no" title="statement not covered" > config.repository.branch,</span>
|
|
913
|
-
<span class="cstat-no" title="statement not covered" > config.githubToken</span>
|
|
914
|
-
<span class="cstat-no" title="statement not covered" > );</span>
|
|
915
|
-
<span class="cstat-no" title="statement not covered" > } else {</span>
|
|
916
|
-
<span class="cstat-no" title="statement not covered" > workspacePath = await this.repositoryManager.getWorkspacePath(</span>
|
|
917
|
-
<span class="cstat-no" title="statement not covered" > workspaceId</span>
|
|
918
|
-
<span class="cstat-no" title="statement not covered" > );</span>
|
|
919
|
-
<span class="cstat-no" title="statement not covered" > }</span>
|
|
920
|
-
<span class="cstat-no" title="statement not covered" ></span>
|
|
921
|
-
<span class="cstat-no" title="statement not covered" > // Fetch GitHub tokens from orchestrator API</span>
|
|
922
|
-
<span class="cstat-no" title="statement not covered" > const githubToken = await this.fetchGithubTokens(workspaceId);</span>
|
|
923
|
-
<span class="cstat-no" title="statement not covered" ></span>
|
|
924
|
-
<span class="cstat-no" title="statement not covered" > // Build claude conversation</span>
|
|
925
|
-
<span class="cstat-no" title="statement not covered" > const builder = claude()</span>
|
|
926
|
-
<span class="cstat-no" title="statement not covered" > .withExecutable(require.resolve("@anthropic-ai/claude-code/cli.js"))</span>
|
|
927
|
-
<span class="cstat-no" title="statement not covered" > .withEnv({</span>
|
|
928
|
-
<span class="cstat-no" title="statement not covered" > ANTHROPIC_API_KEY: config.anthropicApiKey || "",</span>
|
|
929
|
-
<span class="cstat-no" title="statement not covered" > ...(githubToken && { GITHUB_TOKEN: githubToken }),</span>
|
|
930
|
-
<span class="cstat-no" title="statement not covered" > })</span>
|
|
931
|
-
<span class="cstat-no" title="statement not covered" > .withModel(config.model)</span>
|
|
932
|
-
<span class="cstat-no" title="statement not covered" > .inDirectory(workspacePath)</span>
|
|
933
|
-
<span class="cstat-no" title="statement not covered" > .skipPermissions(); // Runner manages permissions</span>
|
|
934
|
-
<span class="cstat-no" title="statement not covered" ></span>
|
|
935
|
-
<span class="cstat-no" title="statement not covered" > // Add session ID if resuming</span>
|
|
936
|
-
<span class="cstat-no" title="statement not covered" > if (config.sessionId) {</span>
|
|
937
|
-
<span class="cstat-no" title="statement not covered" > builder.withSessionId(config.sessionId);</span>
|
|
938
|
-
<span class="cstat-no" title="statement not covered" > }</span>
|
|
939
|
-
<span class="cstat-no" title="statement not covered" ></span>
|
|
940
|
-
<span class="cstat-no" title="statement not covered" > // Configure MCP servers from orchestrator</span>
|
|
941
|
-
<span class="cstat-no" title="statement not covered" > if (config.mcpServers) {</span>
|
|
942
|
-
<span class="cstat-no" title="statement not covered" > // Pass MCP configuration directly from orchestrator to Claude SDK</span>
|
|
943
|
-
<span class="cstat-no" title="statement not covered" > // The runner does not define or modify MCP tools</span>
|
|
944
|
-
<span class="cstat-no" title="statement not covered" > builder.withMCP(config.mcpServers);</span>
|
|
945
|
-
<span class="cstat-no" title="statement not covered" > }</span>
|
|
946
|
-
<span class="cstat-no" title="statement not covered" ></span>
|
|
947
|
-
<span class="cstat-no" title="statement not covered" > // Set up process completion handler</span>
|
|
948
|
-
<span class="cstat-no" title="statement not covered" > builder.onProcessComplete(async (exitCode, error) => {</span>
|
|
949
|
-
<span class="cstat-no" title="statement not covered" > if (error) {</span>
|
|
950
|
-
<span class="cstat-no" title="statement not covered" > await this.runner.notify("error.report", {</span>
|
|
951
|
-
<span class="cstat-no" title="statement not covered" > taskId,</span>
|
|
952
|
-
<span class="cstat-no" title="statement not covered" > sessionId: context.sessionId || undefined,</span>
|
|
953
|
-
<span class="cstat-no" title="statement not covered" > errorType: "process_exit",</span>
|
|
954
|
-
<span class="cstat-no" title="statement not covered" > message: error.message || `Process exited with code ${exitCode}`,</span>
|
|
955
|
-
<span class="cstat-no" title="statement not covered" > details: { exitCode },</span>
|
|
956
|
-
<span class="cstat-no" title="statement not covered" > });</span>
|
|
957
|
-
<span class="cstat-no" title="statement not covered" > }</span>
|
|
958
|
-
<span class="cstat-no" title="statement not covered" ></span>
|
|
959
|
-
<span class="cstat-no" title="statement not covered" > // Notify orchestrator that conversation ended</span>
|
|
960
|
-
<span class="cstat-no" title="statement not covered" > await this.runner.notify("conversation.end", {</span>
|
|
961
|
-
<span class="cstat-no" title="statement not covered" > taskId,</span>
|
|
962
|
-
<span class="cstat-no" title="statement not covered" > isError: exitCode !== 0,</span>
|
|
963
|
-
<span class="cstat-no" title="statement not covered" > errorMessage: error?.message,</span>
|
|
964
|
-
<span class="cstat-no" title="statement not covered" > });</span>
|
|
965
|
-
<span class="cstat-no" title="statement not covered" > </span>
|
|
966
|
-
<span class="cstat-no" title="statement not covered" > // Clean up conversation from active conversations</span>
|
|
967
|
-
<span class="cstat-no" title="statement not covered" > this.runner.activeConversations_.delete(taskId);</span>
|
|
968
|
-
<span class="cstat-no" title="statement not covered" > </span>
|
|
969
|
-
<span class="cstat-no" title="statement not covered" > // Update status line</span>
|
|
970
|
-
<span class="cstat-no" title="statement not covered" > statusLineManager.updateActiveCount(this.runner.activeConversations_.size);</span>
|
|
971
|
-
<span class="cstat-no" title="statement not covered" > });</span>
|
|
972
|
-
<span class="cstat-no" title="statement not covered" ></span>
|
|
973
|
-
<span class="cstat-no" title="statement not covered" > // Create conversation instance</span>
|
|
974
|
-
<span class="cstat-no" title="statement not covered" > const conversation = builder.asConversation();</span>
|
|
975
|
-
<span class="cstat-no" title="statement not covered" ></span>
|
|
976
|
-
<span class="cstat-no" title="statement not covered" > // Store conversation instance in context for reuse</span>
|
|
977
|
-
<span class="cstat-no" title="statement not covered" > context.conversation = conversation;</span>
|
|
978
|
-
<span class="cstat-no" title="statement not covered" ></span>
|
|
979
|
-
<span class="cstat-no" title="statement not covered" > // Set up session ID callback</span>
|
|
980
|
-
<span class="cstat-no" title="statement not covered" > conversation.onSessionId(async (sessionId) => {</span>
|
|
981
|
-
<span class="cstat-no" title="statement not covered" > // Update conversation context</span>
|
|
982
|
-
<span class="cstat-no" title="statement not covered" > const context = this.runner.getConversationContext(taskId);</span>
|
|
983
|
-
<span class="cstat-no" title="statement not covered" > context.sessionId = sessionId || undefined;</span>
|
|
984
|
-
<span class="cstat-no" title="statement not covered" > context.status = "active";</span>
|
|
985
|
-
<span class="cstat-no" title="statement not covered" ></span>
|
|
986
|
-
<span class="cstat-no" title="statement not covered" > // Notify orchestrator of session creation/update</span>
|
|
987
|
-
<span class="cstat-no" title="statement not covered" > await this.runner.notify("session.changed", {</span>
|
|
988
|
-
<span class="cstat-no" title="statement not covered" > taskId,</span>
|
|
989
|
-
<span class="cstat-no" title="statement not covered" > sessionId,</span>
|
|
990
|
-
<span class="cstat-no" title="statement not covered" > });</span>
|
|
991
|
-
<span class="cstat-no" title="statement not covered" > });</span>
|
|
992
|
-
<span class="cstat-no" title="statement not covered" ></span>
|
|
993
|
-
<span class="cstat-no" title="statement not covered" > // Set up streaming message handler</span>
|
|
994
|
-
<span class="cstat-no" title="statement not covered" > const messageHandler = async (message: SDKMessage, sessionId: string | null) => {</span>
|
|
995
|
-
<span class="cstat-no" title="statement not covered" > await this.handleStreamedMessage(taskId, message, sessionId);</span>
|
|
996
|
-
<span class="cstat-no" title="statement not covered" > };</span>
|
|
997
|
-
<span class="cstat-no" title="statement not covered" ></span>
|
|
998
|
-
<span class="cstat-no" title="statement not covered" > conversation.stream(messageHandler);</span>
|
|
999
|
-
<span class="cstat-no" title="statement not covered" ></span>
|
|
1000
|
-
<span class="cstat-no" title="statement not covered" > // Note: Error handling is done via process completion handler</span>
|
|
1001
|
-
<span class="cstat-no" title="statement not covered" > // The Claude SDK doesn't have an onError method on conversations</span>
|
|
1002
|
-
<span class="cstat-no" title="statement not covered" ></span>
|
|
1003
|
-
<span class="cstat-no" title="statement not covered" > // Send initial messages</span>
|
|
1004
|
-
<span class="cstat-no" title="statement not covered" > try {</span>
|
|
1005
|
-
<span class="cstat-no" title="statement not covered" > for (const message of initialMessages) {</span>
|
|
1006
|
-
<span class="cstat-no" title="statement not covered" > conversation.send({</span>
|
|
1007
|
-
<span class="cstat-no" title="statement not covered" > type: "text",</span>
|
|
1008
|
-
<span class="cstat-no" title="statement not covered" > text: message.content,</span>
|
|
1009
|
-
<span class="cstat-no" title="statement not covered" > });</span>
|
|
1010
|
-
<span class="cstat-no" title="statement not covered" > }</span>
|
|
1011
|
-
<span class="cstat-no" title="statement not covered" > </span>
|
|
1012
|
-
<span class="cstat-no" title="statement not covered" > console.log(`Started conversation for task ${taskId} in workspace ${workspacePath}`);</span>
|
|
1013
|
-
<span class="cstat-no" title="statement not covered" > } catch (error) {</span>
|
|
1014
|
-
<span class="cstat-no" title="statement not covered" > // Handle startup errors</span>
|
|
1015
|
-
<span class="cstat-no" title="statement not covered" > await this._handleConversationError(taskId, context.sessionId || "", error as Error);</span>
|
|
1016
|
-
<span class="cstat-no" title="statement not covered" > throw error;</span>
|
|
1017
|
-
<span class="cstat-no" title="statement not covered" > }</span>
|
|
1018
|
-
<span class="cstat-no" title="statement not covered" > }</span>
|
|
1019
|
-
<span class="cstat-no" title="statement not covered" ></span>
|
|
1020
|
-
<span class="cstat-no" title="statement not covered" > async stopConversation(taskId: string, _sessionId: string): Promise<void> {</span>
|
|
1021
|
-
<span class="cstat-no" title="statement not covered" > const context = this.runner.getConversationContext(taskId);</span>
|
|
1022
|
-
<span class="cstat-no" title="statement not covered" > if (context && context.conversation) {</span>
|
|
1023
|
-
<span class="cstat-no" title="statement not covered" > context.status = "stopping";</span>
|
|
1024
|
-
<span class="cstat-no" title="statement not covered" > </span>
|
|
1025
|
-
<span class="cstat-no" title="statement not covered" > try {</span>
|
|
1026
|
-
<span class="cstat-no" title="statement not covered" > // Properly end the conversation using the SDK</span>
|
|
1027
|
-
<span class="cstat-no" title="statement not covered" > await context.conversation.end();</span>
|
|
1028
|
-
<span class="cstat-no" title="statement not covered" > } catch (error) {</span>
|
|
1029
|
-
<span class="cstat-no" title="statement not covered" > console.error(`Error ending conversation for task ${taskId}:`, error);</span>
|
|
1030
|
-
<span class="cstat-no" title="statement not covered" > }</span>
|
|
1031
|
-
<span class="cstat-no" title="statement not covered" > </span>
|
|
1032
|
-
<span class="cstat-no" title="statement not covered" > // Clean up conversation reference</span>
|
|
1033
|
-
<span class="cstat-no" title="statement not covered" > delete context.conversation;</span>
|
|
1034
|
-
<span class="cstat-no" title="statement not covered" > context.status = "stopped";</span>
|
|
1035
|
-
<span class="cstat-no" title="statement not covered" > }</span>
|
|
1036
|
-
<span class="cstat-no" title="statement not covered" ></span>
|
|
1037
|
-
<span class="cstat-no" title="statement not covered" > console.log(</span>
|
|
1038
|
-
<span class="cstat-no" title="statement not covered" > `Stopped conversation for task ${taskId}, session ${_sessionId}`</span>
|
|
1039
|
-
<span class="cstat-no" title="statement not covered" > );</span>
|
|
1040
|
-
<span class="cstat-no" title="statement not covered" > }</span>
|
|
1041
|
-
<span class="cstat-no" title="statement not covered" ></span>
|
|
1042
|
-
<span class="cstat-no" title="statement not covered" > async resumeConversation(</span>
|
|
1043
|
-
<span class="cstat-no" title="statement not covered" > taskId: string,</span>
|
|
1044
|
-
<span class="cstat-no" title="statement not covered" > _sessionId: string,</span>
|
|
1045
|
-
<span class="cstat-no" title="statement not covered" > config: ConversationConfig</span>
|
|
1046
|
-
<span class="cstat-no" title="statement not covered" > ): Promise<void> {</span>
|
|
1047
|
-
<span class="cstat-no" title="statement not covered" > // Resume is handled by starting a new conversation with the existing session ID</span>
|
|
1048
|
-
<span class="cstat-no" title="statement not covered" > await this.startConversation(taskId, { ...config, sessionId: _sessionId }, []);</span>
|
|
1049
|
-
<span class="cstat-no" title="statement not covered" > }</span>
|
|
1050
|
-
<span class="cstat-no" title="statement not covered" ></span>
|
|
1051
|
-
<span class="cstat-no" title="statement not covered" > async sendUserMessage(</span>
|
|
1052
|
-
<span class="cstat-no" title="statement not covered" > taskId: string,</span>
|
|
1053
|
-
<span class="cstat-no" title="statement not covered" > _sessionId: string,</span>
|
|
1054
|
-
<span class="cstat-no" title="statement not covered" > content: string</span>
|
|
1055
|
-
<span class="cstat-no" title="statement not covered" > ): Promise<void> {</span>
|
|
1056
|
-
<span class="cstat-no" title="statement not covered" > const context = this.runner.getConversationContext(taskId);</span>
|
|
1057
|
-
<span class="cstat-no" title="statement not covered" ></span>
|
|
1058
|
-
<span class="cstat-no" title="statement not covered" > try {</span>
|
|
1059
|
-
<span class="cstat-no" title="statement not covered" > // Verify conversation is active</span>
|
|
1060
|
-
<span class="cstat-no" title="statement not covered" > if (context.status !== "active") {</span>
|
|
1061
|
-
<span class="cstat-no" title="statement not covered" > throw new Error(</span>
|
|
1062
|
-
<span class="cstat-no" title="statement not covered" > `Conversation ${taskId} is not active (status: ${context.status})`</span>
|
|
1063
|
-
<span class="cstat-no" title="statement not covered" > );</span>
|
|
1064
|
-
<span class="cstat-no" title="statement not covered" > }</span>
|
|
1065
|
-
<span class="cstat-no" title="statement not covered" ></span>
|
|
1066
|
-
<span class="cstat-no" title="statement not covered" > // Use existing conversation object (stateful)</span>
|
|
1067
|
-
<span class="cstat-no" title="statement not covered" > if (!context.conversation) {</span>
|
|
1068
|
-
<span class="cstat-no" title="statement not covered" > throw new Error(</span>
|
|
1069
|
-
<span class="cstat-no" title="statement not covered" > `No conversation instance found for task ${taskId}`</span>
|
|
1070
|
-
<span class="cstat-no" title="statement not covered" > );</span>
|
|
1071
|
-
<span class="cstat-no" title="statement not covered" > }</span>
|
|
1072
|
-
<span class="cstat-no" title="statement not covered" ></span>
|
|
1073
|
-
<span class="cstat-no" title="statement not covered" > // Send message to existing conversation</span>
|
|
1074
|
-
<span class="cstat-no" title="statement not covered" > context.conversation.send({</span>
|
|
1075
|
-
<span class="cstat-no" title="statement not covered" > type: "text",</span>
|
|
1076
|
-
<span class="cstat-no" title="statement not covered" > text: content,</span>
|
|
1077
|
-
<span class="cstat-no" title="statement not covered" > });</span>
|
|
1078
|
-
<span class="cstat-no" title="statement not covered" ></span>
|
|
1079
|
-
<span class="cstat-no" title="statement not covered" > // Update last activity</span>
|
|
1080
|
-
<span class="cstat-no" title="statement not covered" > context.lastActivityAt = new Date();</span>
|
|
1081
|
-
<span class="cstat-no" title="statement not covered" > </span>
|
|
1082
|
-
<span class="cstat-no" title="statement not covered" > console.log(`Sent user message to conversation ${taskId}`);</span>
|
|
1083
|
-
<span class="cstat-no" title="statement not covered" > } catch (error) {</span>
|
|
1084
|
-
<span class="cstat-no" title="statement not covered" > // Handle errors properly</span>
|
|
1085
|
-
<span class="cstat-no" title="statement not covered" > await this._handleConversationError(taskId, _sessionId, error as Error);</span>
|
|
1086
|
-
<span class="cstat-no" title="statement not covered" > throw error; // Re-throw to maintain the same behavior</span>
|
|
1087
|
-
<span class="cstat-no" title="statement not covered" > }</span>
|
|
1088
|
-
<span class="cstat-no" title="statement not covered" > }</span>
|
|
1089
|
-
<span class="cstat-no" title="statement not covered" ></span>
|
|
1090
|
-
<span class="cstat-no" title="statement not covered" > private async fetchGithubTokens(</span>
|
|
1091
|
-
<span class="cstat-no" title="statement not covered" > workspaceId: string</span>
|
|
1092
|
-
<span class="cstat-no" title="statement not covered" > ): Promise<string | undefined> {</span>
|
|
1093
|
-
<span class="cstat-no" title="statement not covered" > try {</span>
|
|
1094
|
-
<span class="cstat-no" title="statement not covered" > const response = await fetch(</span>
|
|
1095
|
-
<span class="cstat-no" title="statement not covered" > `${this.runner.config_.orchestratorUrl}/api/runner/tokens?workspaceId=${workspaceId}`,</span>
|
|
1096
|
-
<span class="cstat-no" title="statement not covered" > {</span>
|
|
1097
|
-
<span class="cstat-no" title="statement not covered" > method: "GET",</span>
|
|
1098
|
-
<span class="cstat-no" title="statement not covered" > headers: {</span>
|
|
1099
|
-
<span class="cstat-no" title="statement not covered" > Authorization: `Bearer ${process.env["NORTHFLARE_RUNNER_TOKEN"]}`,</span>
|
|
1100
|
-
<span class="cstat-no" title="statement not covered" > },</span>
|
|
1101
|
-
<span class="cstat-no" title="statement not covered" > }</span>
|
|
1102
|
-
<span class="cstat-no" title="statement not covered" > );</span>
|
|
1103
|
-
<span class="cstat-no" title="statement not covered" ></span>
|
|
1104
|
-
<span class="cstat-no" title="statement not covered" > if (!response.ok) {</span>
|
|
1105
|
-
<span class="cstat-no" title="statement not covered" > console.error(`Failed to fetch GitHub tokens: ${response.status}`);</span>
|
|
1106
|
-
<span class="cstat-no" title="statement not covered" > return undefined;</span>
|
|
1107
|
-
<span class="cstat-no" title="statement not covered" > }</span>
|
|
1108
|
-
<span class="cstat-no" title="statement not covered" ></span>
|
|
1109
|
-
<span class="cstat-no" title="statement not covered" > const data = await response.json() as { githubToken?: string };</span>
|
|
1110
|
-
<span class="cstat-no" title="statement not covered" > return data.githubToken;</span>
|
|
1111
|
-
<span class="cstat-no" title="statement not covered" > } catch (error) {</span>
|
|
1112
|
-
<span class="cstat-no" title="statement not covered" > console.error("Error fetching GitHub tokens:", error);</span>
|
|
1113
|
-
<span class="cstat-no" title="statement not covered" > return undefined;</span>
|
|
1114
|
-
<span class="cstat-no" title="statement not covered" > }</span>
|
|
1115
|
-
<span class="cstat-no" title="statement not covered" > }</span>
|
|
1116
|
-
<span class="cstat-no" title="statement not covered" ></span>
|
|
1117
|
-
<span class="cstat-no" title="statement not covered" > private async _handleConversationError(</span>
|
|
1118
|
-
<span class="cstat-no" title="statement not covered" > taskId: string,</span>
|
|
1119
|
-
<span class="cstat-no" title="statement not covered" > _sessionId: string,</span>
|
|
1120
|
-
<span class="cstat-no" title="statement not covered" > error: Error</span>
|
|
1121
|
-
<span class="cstat-no" title="statement not covered" > ): Promise<void> {</span>
|
|
1122
|
-
<span class="cstat-no" title="statement not covered" > const errorType = this.classifyError(error);</span>
|
|
1123
|
-
<span class="cstat-no" title="statement not covered" ></span>
|
|
1124
|
-
<span class="cstat-no" title="statement not covered" > // Notify orchestrator</span>
|
|
1125
|
-
<span class="cstat-no" title="statement not covered" > await this.runner.notify("error.report", {</span>
|
|
1126
|
-
<span class="cstat-no" title="statement not covered" > taskId,</span>
|
|
1127
|
-
<span class="cstat-no" title="statement not covered" > sessionId: _sessionId,</span>
|
|
1128
|
-
<span class="cstat-no" title="statement not covered" > errorType,</span>
|
|
1129
|
-
<span class="cstat-no" title="statement not covered" > message: error.message,</span>
|
|
1130
|
-
<span class="cstat-no" title="statement not covered" > details: {</span>
|
|
1131
|
-
<span class="cstat-no" title="statement not covered" > stack: error.stack,</span>
|
|
1132
|
-
<span class="cstat-no" title="statement not covered" > timestamp: new Date(),</span>
|
|
1133
|
-
<span class="cstat-no" title="statement not covered" > },</span>
|
|
1134
|
-
<span class="cstat-no" title="statement not covered" > });</span>
|
|
1135
|
-
<span class="cstat-no" title="statement not covered" ></span>
|
|
1136
|
-
<span class="cstat-no" title="statement not covered" > // Conversation continues on error - no automatic cleanup</span>
|
|
1137
|
-
<span class="cstat-no" title="statement not covered" > console.error(`Conversation error for task ${taskId}:`, error);</span>
|
|
1138
|
-
<span class="cstat-no" title="statement not covered" > }</span>
|
|
1139
|
-
<span class="cstat-no" title="statement not covered" ></span>
|
|
1140
|
-
<span class="cstat-no" title="statement not covered" > private classifyError(error: Error): string {</span>
|
|
1141
|
-
<span class="cstat-no" title="statement not covered" > if (error.message.includes("process exited")) {</span>
|
|
1142
|
-
<span class="cstat-no" title="statement not covered" > return "process_exit";</span>
|
|
1143
|
-
<span class="cstat-no" title="statement not covered" > } else if (error.message.includes("model")) {</span>
|
|
1144
|
-
<span class="cstat-no" title="statement not covered" > return "model_error";</span>
|
|
1145
|
-
<span class="cstat-no" title="statement not covered" > } else if (error.message.includes("tool")) {</span>
|
|
1146
|
-
<span class="cstat-no" title="statement not covered" > return "tool_error";</span>
|
|
1147
|
-
<span class="cstat-no" title="statement not covered" > } else if (error.message.includes("permission")) {</span>
|
|
1148
|
-
<span class="cstat-no" title="statement not covered" > return "permission_error";</span>
|
|
1149
|
-
<span class="cstat-no" title="statement not covered" > } else if (error.message.includes("timeout")) {</span>
|
|
1150
|
-
<span class="cstat-no" title="statement not covered" > return "timeout_error";</span>
|
|
1151
|
-
<span class="cstat-no" title="statement not covered" > }</span>
|
|
1152
|
-
<span class="cstat-no" title="statement not covered" > return "unknown_error";</span>
|
|
1153
|
-
<span class="cstat-no" title="statement not covered" > }</span>
|
|
1154
|
-
<span class="cstat-no" title="statement not covered" ></span>
|
|
1155
|
-
<span class="cstat-no" title="statement not covered" > private async handleStreamedMessage(</span>
|
|
1156
|
-
<span class="cstat-no" title="statement not covered" > taskId: string,</span>
|
|
1157
|
-
<span class="cstat-no" title="statement not covered" > message: SDKMessage,</span>
|
|
1158
|
-
<span class="cstat-no" title="statement not covered" > sessionId: string | null</span>
|
|
1159
|
-
<span class="cstat-no" title="statement not covered" > ): Promise<void> {</span>
|
|
1160
|
-
<span class="cstat-no" title="statement not covered" > try {</span>
|
|
1161
|
-
<span class="cstat-no" title="statement not covered" > console.log(`Received streamed message for task ${taskId}`, {</span>
|
|
1162
|
-
<span class="cstat-no" title="statement not covered" > type: message.type,</span>
|
|
1163
|
-
<span class="cstat-no" title="statement not covered" > });</span>
|
|
1164
|
-
<span class="cstat-no" title="statement not covered" ></span>
|
|
1165
|
-
<span class="cstat-no" title="statement not covered" > // Map SDK message types to our protocol</span>
|
|
1166
|
-
<span class="cstat-no" title="statement not covered" > let messageType: string = message.type;</span>
|
|
1167
|
-
<span class="cstat-no" title="statement not covered" > let content = "";</span>
|
|
1168
|
-
<span class="cstat-no" title="statement not covered" > let toolCalls: any[] | undefined;</span>
|
|
1169
|
-
<span class="cstat-no" title="statement not covered" ></span>
|
|
1170
|
-
<span class="cstat-no" title="statement not covered" > // Extract content and tool calls based on message type</span>
|
|
1171
|
-
<span class="cstat-no" title="statement not covered" > if (message.type === "assistant") {</span>
|
|
1172
|
-
<span class="cstat-no" title="statement not covered" > const assistantMsg = message as any; // Type assertion for assistant message</span>
|
|
1173
|
-
<span class="cstat-no" title="statement not covered" > if (assistantMsg.content) {</span>
|
|
1174
|
-
<span class="cstat-no" title="statement not covered" > // Extract text content from content blocks</span>
|
|
1175
|
-
<span class="cstat-no" title="statement not covered" > const textBlocks = assistantMsg.content.filter((b: any) => b.type === "text");</span>
|
|
1176
|
-
<span class="cstat-no" title="statement not covered" > content = textBlocks.map((b: any) => b.text).join("");</span>
|
|
1177
|
-
<span class="cstat-no" title="statement not covered" > </span>
|
|
1178
|
-
<span class="cstat-no" title="statement not covered" > // Extract tool calls</span>
|
|
1179
|
-
<span class="cstat-no" title="statement not covered" > const toolUseBlocks = assistantMsg.content.filter((b: any) => b.type === "tool_use");</span>
|
|
1180
|
-
<span class="cstat-no" title="statement not covered" > if (toolUseBlocks.length > 0) {</span>
|
|
1181
|
-
<span class="cstat-no" title="statement not covered" > toolCalls = toolUseBlocks.map((b: any) => ({</span>
|
|
1182
|
-
<span class="cstat-no" title="statement not covered" > id: b.id,</span>
|
|
1183
|
-
<span class="cstat-no" title="statement not covered" > name: b.name,</span>
|
|
1184
|
-
<span class="cstat-no" title="statement not covered" > arguments: b.input</span>
|
|
1185
|
-
<span class="cstat-no" title="statement not covered" > }));</span>
|
|
1186
|
-
<span class="cstat-no" title="statement not covered" > }</span>
|
|
1187
|
-
<span class="cstat-no" title="statement not covered" > }</span>
|
|
1188
|
-
<span class="cstat-no" title="statement not covered" > } else if (message.type === "result") {</span>
|
|
1189
|
-
<span class="cstat-no" title="statement not covered" > const resultMsg = message as any;</span>
|
|
1190
|
-
<span class="cstat-no" title="statement not covered" > content = resultMsg.content || resultMsg.result || "";</span>
|
|
1191
|
-
<span class="cstat-no" title="statement not covered" > } else if (message.type === "user") {</span>
|
|
1192
|
-
<span class="cstat-no" title="statement not covered" > const userMsg = message as any;</span>
|
|
1193
|
-
<span class="cstat-no" title="statement not covered" > content = typeof userMsg.content === "string" ? userMsg.content : "";</span>
|
|
1194
|
-
<span class="cstat-no" title="statement not covered" > }</span>
|
|
1195
|
-
<span class="cstat-no" title="statement not covered" ></span>
|
|
1196
|
-
<span class="cstat-no" title="statement not covered" > // Send agent message to orchestrator</span>
|
|
1197
|
-
<span class="cstat-no" title="statement not covered" > await this.runner.notify("message.agent", {</span>
|
|
1198
|
-
<span class="cstat-no" title="statement not covered" > taskId,</span>
|
|
1199
|
-
<span class="cstat-no" title="statement not covered" > sessionId: sessionId || undefined,</span>
|
|
1200
|
-
<span class="cstat-no" title="statement not covered" > type: messageType,</span>
|
|
1201
|
-
<span class="cstat-no" title="statement not covered" > content,</span>
|
|
1202
|
-
<span class="cstat-no" title="statement not covered" > toolCalls,</span>
|
|
1203
|
-
<span class="cstat-no" title="statement not covered" > isError: false,</span>
|
|
1204
|
-
<span class="cstat-no" title="statement not covered" > });</span>
|
|
1205
|
-
<span class="cstat-no" title="statement not covered" ></span>
|
|
1206
|
-
<span class="cstat-no" title="statement not covered" > // Handle tool calls if present</span>
|
|
1207
|
-
<span class="cstat-no" title="statement not covered" > if (toolCalls && toolCalls.length > 0) {</span>
|
|
1208
|
-
<span class="cstat-no" title="statement not covered" > for (const toolCall of toolCalls) {</span>
|
|
1209
|
-
<span class="cstat-no" title="statement not covered" > console.log(`Processing tool call: ${toolCall.name}`, {</span>
|
|
1210
|
-
<span class="cstat-no" title="statement not covered" > taskId,</span>
|
|
1211
|
-
<span class="cstat-no" title="statement not covered" > toolId: toolCall.id,</span>
|
|
1212
|
-
<span class="cstat-no" title="statement not covered" > });</span>
|
|
1213
|
-
<span class="cstat-no" title="statement not covered" ></span>
|
|
1214
|
-
<span class="cstat-no" title="statement not covered" > try {</span>
|
|
1215
|
-
<span class="cstat-no" title="statement not covered" > // Request tool execution from orchestrator</span>
|
|
1216
|
-
<span class="cstat-no" title="statement not covered" > const result = await this.runner.sendToOrchestrator({</span>
|
|
1217
|
-
<span class="cstat-no" title="statement not covered" > jsonrpc: "2.0",</span>
|
|
1218
|
-
<span class="cstat-no" title="statement not covered" > id: toolCall.id,</span>
|
|
1219
|
-
<span class="cstat-no" title="statement not covered" > method: "toolCall.request",</span>
|
|
1220
|
-
<span class="cstat-no" title="statement not covered" > params: {</span>
|
|
1221
|
-
<span class="cstat-no" title="statement not covered" > taskId,</span>
|
|
1222
|
-
<span class="cstat-no" title="statement not covered" > sessionId,</span>
|
|
1223
|
-
<span class="cstat-no" title="statement not covered" > tool: toolCall.name,</span>
|
|
1224
|
-
<span class="cstat-no" title="statement not covered" > arguments: toolCall.arguments,</span>
|
|
1225
|
-
<span class="cstat-no" title="statement not covered" > },</span>
|
|
1226
|
-
<span class="cstat-no" title="statement not covered" > });</span>
|
|
1227
|
-
<span class="cstat-no" title="statement not covered" ></span>
|
|
1228
|
-
<span class="cstat-no" title="statement not covered" > // Send tool result back to conversation</span>
|
|
1229
|
-
<span class="cstat-no" title="statement not covered" > const context = this.runner.getConversationContext(taskId);</span>
|
|
1230
|
-
<span class="cstat-no" title="statement not covered" > if (result && context.conversation) {</span>
|
|
1231
|
-
<span class="cstat-no" title="statement not covered" > // Send tool result as text since SDK expects text messages</span>
|
|
1232
|
-
<span class="cstat-no" title="statement not covered" > const resultText = JSON.stringify(result);</span>
|
|
1233
|
-
<span class="cstat-no" title="statement not covered" > context.conversation.send({</span>
|
|
1234
|
-
<span class="cstat-no" title="statement not covered" > type: "text",</span>
|
|
1235
|
-
<span class="cstat-no" title="statement not covered" > text: `Tool result for ${toolCall.name}: ${resultText}`,</span>
|
|
1236
|
-
<span class="cstat-no" title="statement not covered" > });</span>
|
|
1237
|
-
<span class="cstat-no" title="statement not covered" > }</span>
|
|
1238
|
-
<span class="cstat-no" title="statement not covered" > } catch (error) {</span>
|
|
1239
|
-
<span class="cstat-no" title="statement not covered" > console.error(`[RPC Error] Tool call failed: ${toolCall.name}`, {</span>
|
|
1240
|
-
<span class="cstat-no" title="statement not covered" > taskId,</span>
|
|
1241
|
-
<span class="cstat-no" title="statement not covered" > sessionId,</span>
|
|
1242
|
-
<span class="cstat-no" title="statement not covered" > tool: toolCall.name,</span>
|
|
1243
|
-
<span class="cstat-no" title="statement not covered" > error: error instanceof Error ? error.message : error,</span>
|
|
1244
|
-
<span class="cstat-no" title="statement not covered" > stack: error instanceof Error ? error.stack : undefined</span>
|
|
1245
|
-
<span class="cstat-no" title="statement not covered" > });</span>
|
|
1246
|
-
<span class="cstat-no" title="statement not covered" > </span>
|
|
1247
|
-
<span class="cstat-no" title="statement not covered" > // Send error result back to conversation</span>
|
|
1248
|
-
<span class="cstat-no" title="statement not covered" > const context = this.runner.getConversationContext(taskId);</span>
|
|
1249
|
-
<span class="cstat-no" title="statement not covered" > if (context.conversation) {</span>
|
|
1250
|
-
<span class="cstat-no" title="statement not covered" > // Send error result as text</span>
|
|
1251
|
-
<span class="cstat-no" title="statement not covered" > const errorMsg = error instanceof Error ? error.message : String(error);</span>
|
|
1252
|
-
<span class="cstat-no" title="statement not covered" > context.conversation.send({</span>
|
|
1253
|
-
<span class="cstat-no" title="statement not covered" > type: "text",</span>
|
|
1254
|
-
<span class="cstat-no" title="statement not covered" > text: `Tool error for ${toolCall.name}: ${errorMsg}`,</span>
|
|
1255
|
-
<span class="cstat-no" title="statement not covered" > });</span>
|
|
1256
|
-
<span class="cstat-no" title="statement not covered" > }</span>
|
|
1257
|
-
<span class="cstat-no" title="statement not covered" > }</span>
|
|
1258
|
-
<span class="cstat-no" title="statement not covered" > }</span>
|
|
1259
|
-
<span class="cstat-no" title="statement not covered" > }</span>
|
|
1260
|
-
<span class="cstat-no" title="statement not covered" > } catch (error) {</span>
|
|
1261
|
-
<span class="cstat-no" title="statement not covered" > console.error(`Error handling streamed message for task ${taskId}:`, error);</span>
|
|
1262
|
-
<span class="cstat-no" title="statement not covered" > await this._handleConversationError(taskId, sessionId || "", error as Error);</span>
|
|
1263
|
-
<span class="cstat-no" title="statement not covered" > }</span>
|
|
1264
|
-
<span class="cstat-no" title="statement not covered" > }</span>
|
|
1265
|
-
<span class="cstat-no" title="statement not covered" >}</span></pre></td></tr></table></pre>
|
|
1266
|
-
|
|
1267
|
-
<div class="push"></div>
|
|
1268
|
-
<!-- for sticky footer -->
|
|
1269
|
-
</div>
|
|
1270
|
-
<!-- /wrapper -->
|
|
1271
|
-
<div class="footer quiet pad2 space-top1 center small">
|
|
1272
|
-
Code coverage generated by
|
|
1273
|
-
<a
|
|
1274
|
-
href="https://istanbul.js.org/"
|
|
1275
|
-
target="_blank"
|
|
1276
|
-
rel="noopener noreferrer"
|
|
1277
|
-
>istanbul</a
|
|
1278
|
-
>
|
|
1279
|
-
at 2025-08-14T21:15:54.473Z
|
|
1280
|
-
</div>
|
|
1281
|
-
<script src="../../prettify.js"></script>
|
|
1282
|
-
<script>
|
|
1283
|
-
window.onload = function () {
|
|
1284
|
-
prettyPrint();
|
|
1285
|
-
};
|
|
1286
|
-
</script>
|
|
1287
|
-
<script src="../../sorter.js"></script>
|
|
1288
|
-
<script src="../../block-navigation.js"></script>
|
|
1289
|
-
</body>
|
|
1290
|
-
</html>
|