agentsbestfriend 0.6.1 → 0.7.1

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/index.js CHANGED
@@ -18971,7 +18971,7 @@ Summary:`;
18971
18971
  return data.response.trim();
18972
18972
  }
18973
18973
  async generateEmbedding(text4) {
18974
- const chunkSize = 3500;
18974
+ const chunkSize = 2e3;
18975
18975
  const chunks = [];
18976
18976
  if (text4.length <= chunkSize) {
18977
18977
  chunks.push(text4);
@@ -18995,6 +18995,9 @@ Summary:`;
18995
18995
  });
18996
18996
  if (!res.ok) {
18997
18997
  const body = await res.text();
18998
+ if (res.status >= 400 && res.status < 500) {
18999
+ throw new Error(`embed ${res.status}: ${body}`);
19000
+ }
18998
19001
  throw new LlmUnavailableError("ollama", `embed ${res.status}: ${body}`);
18999
19002
  }
19000
19003
  const data = await res.json();
@@ -19079,6 +19082,7 @@ async function generateSummaries(projectRoot, opts) {
19079
19082
  throw err;
19080
19083
  stats.errors++;
19081
19084
  }
19085
+ opts?.onProgress?.(stats.generated + stats.errors, rows.length, row.path);
19082
19086
  }
19083
19087
  }
19084
19088
  stats.skipped = rows.length === 0 ? db.select({ id: files.id }).from(files).all().length : 0;
@@ -19134,6 +19138,7 @@ async function generateEmbeddings(projectRoot, opts) {
19134
19138
  throw err;
19135
19139
  stats.errors++;
19136
19140
  }
19141
+ opts?.onProgress?.(stats.generated + stats.errors, needsEmbedding.length, row.path);
19137
19142
  }
19138
19143
  }
19139
19144
  stats.skipped = existingEmbeddings.size;
@@ -19307,7 +19312,9 @@ async function initCommand(projectPath) {
19307
19312
  const llmSpinner = clack.spinner();
19308
19313
  llmSpinner.start("Generating LLM summaries...");
19309
19314
  try {
19310
- const sumStats = await generateSummaries(root);
19315
+ const sumStats = await generateSummaries(root, {
19316
+ onProgress: (done, total) => llmSpinner.message(`Generating LLM summaries... (${done}/${total})`)
19317
+ });
19311
19318
  llmSpinner.stop(
19312
19319
  `Summaries: ${sumStats.generated} generated, ${sumStats.skipped} skipped (${sumStats.durationMs}ms)`
19313
19320
  );
@@ -19317,7 +19324,9 @@ async function initCommand(projectPath) {
19317
19324
  const embSpinner = clack.spinner();
19318
19325
  embSpinner.start("Generating embeddings...");
19319
19326
  try {
19320
- const embStats = await generateEmbeddings(root);
19327
+ const embStats = await generateEmbeddings(root, {
19328
+ onProgress: (done, total) => embSpinner.message(`Generating embeddings... (${done}/${total})`)
19329
+ });
19321
19330
  embSpinner.stop(
19322
19331
  `Embeddings: ${embStats.generated} generated, ${embStats.skipped} skipped (${embStats.durationMs}ms)`
19323
19332
  );
@@ -19617,7 +19626,11 @@ async function reindex() {
19617
19626
  const llmSpinner = clack3.spinner();
19618
19627
  llmSpinner.start("Generating LLM summaries...");
19619
19628
  try {
19620
- const sumStats = await generateSummaries(root);
19629
+ const sumStats = await generateSummaries(root, {
19630
+ onProgress: (done, total) => llmSpinner.message(
19631
+ `Generating LLM summaries... (${done}/${total})`
19632
+ )
19633
+ });
19621
19634
  llmSpinner.stop(
19622
19635
  `Summaries: ${sumStats.generated} generated, ${sumStats.skipped} skipped (${sumStats.durationMs}ms)`
19623
19636
  );
@@ -19627,7 +19640,9 @@ async function reindex() {
19627
19640
  const embSpinner = clack3.spinner();
19628
19641
  embSpinner.start("Generating embeddings...");
19629
19642
  try {
19630
- const embStats = await generateEmbeddings(root);
19643
+ const embStats = await generateEmbeddings(root, {
19644
+ onProgress: (done, total) => embSpinner.message(`Generating embeddings... (${done}/${total})`)
19645
+ });
19631
19646
  embSpinner.stop(
19632
19647
  `Embeddings: ${embStats.generated} generated, ${embStats.skipped} skipped (${embStats.durationMs}ms)`
19633
19648
  );
@@ -43414,7 +43429,7 @@ function registerPingTool(server) {
43414
43429
  const status = {
43415
43430
  status: "ok",
43416
43431
  server: "agents-best-friend",
43417
- version: "0.6.1",
43432
+ version: "0.7.1",
43418
43433
  projectRoot,
43419
43434
  timestamp: (/* @__PURE__ */ new Date()).toISOString()
43420
43435
  };
@@ -45543,7 +45558,7 @@ Purely heuristic \u2014 no LLM required. Useful to understand a project's style
45543
45558
 
45544
45559
  // ../server/dist/server.js
45545
45560
  var SERVER_NAME = "agents-best-friend";
45546
- var SERVER_VERSION = "0.6.1";
45561
+ var SERVER_VERSION = "0.7.1";
45547
45562
  function createAbfServer() {
45548
45563
  const server = new McpServer({
45549
45564
  name: SERVER_NAME,
@@ -45592,7 +45607,7 @@ async function startCommand() {
45592
45607
 
45593
45608
  // src/index.ts
45594
45609
  var program = new Command();
45595
- program.name("abf").description("AgentsBestFriend \u2014 AI-first code navigation and analysis tools").version("0.6.1");
45610
+ program.name("abf").description("AgentsBestFriend \u2014 AI-first code navigation and analysis tools").version("0.7.1");
45596
45611
  program.command("start").description("Start the MCP server in stdio mode (for AI agent connections)").action(async () => {
45597
45612
  await startCommand();
45598
45613
  });