@tyvm/knowhow 0.0.89 → 0.0.90
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/CONFIG.md +52 -0
- package/README.md +344 -29
- package/WORKER.md +169 -334
- package/autodoc/chat-guide.md +540 -0
- package/autodoc/cli-reference.md +765 -0
- package/autodoc/config-reference.md +541 -0
- package/autodoc/embeddings-guide.md +566 -0
- package/autodoc/generate-guide.md +477 -0
- package/autodoc/language-plugin-guide.md +443 -0
- package/autodoc/modules-guide.md +352 -0
- package/autodoc/plugins-guide.md +720 -0
- package/autodoc/quickstart-guide.md +129 -0
- package/autodoc/skills-guide.md +468 -0
- package/autodoc/worker-guide.md +526 -0
- package/package.json +1 -1
- package/src/ai.ts +33 -2
- package/src/config.ts +28 -4
- package/src/index.ts +22 -2
- package/src/processors/TokenCompressor.ts +2 -2
- package/src/processors/ToolResponseCache.ts +3 -3
- package/src/processors/tools/grepToolResponse.ts +9 -4
- package/src/processors/tools/jqToolResponse.ts +11 -6
- package/src/processors/tools/listStoredToolResponses.ts +1 -1
- package/src/processors/tools/tailToolResponse.ts +9 -4
- package/ts_build/package.json +1 -1
- package/ts_build/src/ai.js +18 -1
- package/ts_build/src/ai.js.map +1 -1
- package/ts_build/src/config.js +17 -2
- package/ts_build/src/config.js.map +1 -1
- package/ts_build/src/index.js +12 -2
- package/ts_build/src/index.js.map +1 -1
- package/ts_build/src/processors/TokenCompressor.js +2 -2
- package/ts_build/src/processors/TokenCompressor.js.map +1 -1
- package/ts_build/src/processors/ToolResponseCache.js +3 -3
- package/ts_build/src/processors/ToolResponseCache.js.map +1 -1
- package/ts_build/src/processors/tools/grepToolResponse.d.ts +3 -1
- package/ts_build/src/processors/tools/grepToolResponse.js +8 -2
- package/ts_build/src/processors/tools/grepToolResponse.js.map +1 -1
- package/ts_build/src/processors/tools/jqToolResponse.d.ts +3 -1
- package/ts_build/src/processors/tools/jqToolResponse.js +10 -4
- package/ts_build/src/processors/tools/jqToolResponse.js.map +1 -1
- package/ts_build/src/processors/tools/listStoredToolResponses.js +1 -1
- package/ts_build/src/processors/tools/listStoredToolResponses.js.map +1 -1
- package/ts_build/src/processors/tools/tailToolResponse.d.ts +3 -1
- package/ts_build/src/processors/tools/tailToolResponse.js +8 -2
- package/ts_build/src/processors/tools/tailToolResponse.js.map +1 -1
- package/autodoc/chat.mdx +0 -20
- package/autodoc/cli.mdx +0 -11
- package/autodoc/plugins/asana.mdx +0 -47
- package/autodoc/plugins/downloader/downloader.mdx +0 -38
- package/autodoc/plugins/downloader/plugin.mdx +0 -37
- package/autodoc/plugins/downloader/types.mdx +0 -42
- package/autodoc/plugins/embedding.mdx +0 -41
- package/autodoc/plugins/figma.mdx +0 -45
- package/autodoc/plugins/github.mdx +0 -40
- package/autodoc/plugins/jira.mdx +0 -46
- package/autodoc/plugins/language.mdx +0 -37
- package/autodoc/plugins/linear.mdx +0 -35
- package/autodoc/plugins/notion.mdx +0 -38
- package/autodoc/plugins/plugins.mdx +0 -59
- package/autodoc/plugins/types.mdx +0 -51
- package/autodoc/plugins/vim.mdx +0 -39
- package/autodoc/tools/addInternalTools.mdx +0 -1
- package/autodoc/tools/agentCall.mdx +0 -1
- package/autodoc/tools/asana/definitions.mdx +0 -10
- package/autodoc/tools/asana/index.mdx +0 -12
- package/autodoc/tools/askHuman.mdx +0 -1
- package/autodoc/tools/callPlugin.mdx +0 -1
- package/autodoc/tools/embeddingSearch.mdx +0 -1
- package/autodoc/tools/execCommand.mdx +0 -1
- package/autodoc/tools/fileSearch.mdx +0 -1
- package/autodoc/tools/finalAnswer.mdx +0 -1
- package/autodoc/tools/github/definitions.mdx +0 -6
- package/autodoc/tools/github/index.mdx +0 -8
- package/autodoc/tools/index.mdx +0 -14
- package/autodoc/tools/lintFile.mdx +0 -7
- package/autodoc/tools/list.mdx +0 -16
- package/autodoc/tools/modifyFile.mdx +0 -7
- package/autodoc/tools/patch.mdx +0 -9
- package/autodoc/tools/readBlocks.mdx +0 -1
- package/autodoc/tools/readFile.mdx +0 -1
- package/autodoc/tools/scanFile.mdx +0 -1
- package/autodoc/tools/textSearch.mdx +0 -6
- package/autodoc/tools/types/fileblock.mdx +0 -1
- package/autodoc/tools/visionTool.mdx +0 -1
- package/autodoc/tools/writeFile.mdx +0 -1
- package/test-comprehensive.ts +0 -31
|
@@ -0,0 +1,477 @@
|
|
|
1
|
+
# `knowhow generate` Guide
|
|
2
|
+
|
|
3
|
+
`knowhow generate` is the Knowhow CLI command that turns your input files into generated documentation (and other artifacts) by running an AI prompt over the selected sources and writing the results to your configured outputs.
|
|
4
|
+
|
|
5
|
+
It is driven entirely by your local **`.knowhow/knowhow.json`** config—specifically the **`sources`** array.
|
|
6
|
+
|
|
7
|
+
---
|
|
8
|
+
|
|
9
|
+
## What `knowhow generate` does
|
|
10
|
+
|
|
11
|
+
When you run:
|
|
12
|
+
|
|
13
|
+
```bash
|
|
14
|
+
knowhow generate
|
|
15
|
+
```
|
|
16
|
+
|
|
17
|
+
the CLI:
|
|
18
|
+
|
|
19
|
+
1. Loads your Knowhow config from **`.knowhow/knowhow.json`**
|
|
20
|
+
2. For each entry in **`config.sources`**:
|
|
21
|
+
- Expands `source.input` into a list of matching files
|
|
22
|
+
- Resolves `source.prompt` into an MDX prompt template or prompt string
|
|
23
|
+
- Uses the selected `model`/`agent` to summarize/generate content
|
|
24
|
+
- Writes output to either:
|
|
25
|
+
- a single output file, or
|
|
26
|
+
- multiple output files inside an output directory
|
|
27
|
+
3. Skips work when inputs and prompt haven’t changed (hash-based caching)
|
|
28
|
+
|
|
29
|
+
---
|
|
30
|
+
|
|
31
|
+
## `sources` configuration structure
|
|
32
|
+
|
|
33
|
+
`sources` is an array of objects in `.knowhow/knowhow.json`.
|
|
34
|
+
|
|
35
|
+
At runtime, each source object may be handled in one of two ways:
|
|
36
|
+
|
|
37
|
+
- **File generation mode** (default): when `kind` is `"file"` or missing/empty
|
|
38
|
+
- **Plugin/“special kind” mode**: when `kind` is set and is not `"file"` (see `kind` below)
|
|
39
|
+
|
|
40
|
+
### Common fields
|
|
41
|
+
|
|
42
|
+
```jsonc
|
|
43
|
+
{
|
|
44
|
+
"input": "src/**/*.ts",
|
|
45
|
+
"output": ".knowhow/docs/",
|
|
46
|
+
"prompt": "MyPrompt",
|
|
47
|
+
"kind": "file",
|
|
48
|
+
"agent": "Developer",
|
|
49
|
+
"model": "gpt-4o-mini",
|
|
50
|
+
"outputExt": "mdx",
|
|
51
|
+
"outputName": "README"
|
|
52
|
+
}
|
|
53
|
+
```
|
|
54
|
+
|
|
55
|
+
All fields described below are part of `GenerationSource` usage in the generator.
|
|
56
|
+
|
|
57
|
+
---
|
|
58
|
+
|
|
59
|
+
## Field reference
|
|
60
|
+
|
|
61
|
+
### `input` (required)
|
|
62
|
+
Defines which files to read. Supported formats are:
|
|
63
|
+
|
|
64
|
+
- **Single file**
|
|
65
|
+
```json
|
|
66
|
+
{ "input": "src/index.ts" }
|
|
67
|
+
```
|
|
68
|
+
- **Glob**
|
|
69
|
+
```json
|
|
70
|
+
{ "input": "src/**/*.ts" }
|
|
71
|
+
```
|
|
72
|
+
- **Comma-separated list**
|
|
73
|
+
```json
|
|
74
|
+
{ "input": "src/a.ts,src/b.ts,src/c.ts" }
|
|
75
|
+
```
|
|
76
|
+
Comma-separated values are auto-normalized into brace expansion internally.
|
|
77
|
+
- **Brace expansion**
|
|
78
|
+
```json
|
|
79
|
+
{ "input": "{src/a.ts,src/b.ts}" }
|
|
80
|
+
```
|
|
81
|
+
|
|
82
|
+
**Normalization behavior (important):**
|
|
83
|
+
- If `input` contains `{`, `*`, or `?`, it is used as-is.
|
|
84
|
+
- If `input` contains commas and no glob/braces, commas are converted into `{a,b,c}`.
|
|
85
|
+
- Otherwise, it’s treated as a glob/pattern directly.
|
|
86
|
+
|
|
87
|
+
---
|
|
88
|
+
|
|
89
|
+
### `output` (required)
|
|
90
|
+
Defines where generated content is written.
|
|
91
|
+
|
|
92
|
+
Two output modes exist:
|
|
93
|
+
|
|
94
|
+
#### 1) Directory mode (multi-output)
|
|
95
|
+
If `output` **ends with `/`**, each input file becomes its own output file:
|
|
96
|
+
|
|
97
|
+
```json
|
|
98
|
+
{
|
|
99
|
+
"input": "src/**/*.ts",
|
|
100
|
+
"output": ".knowhow/docs/",
|
|
101
|
+
"outputExt": "mdx"
|
|
102
|
+
}
|
|
103
|
+
```
|
|
104
|
+
|
|
105
|
+
- Output file name defaults to the input file’s base name
|
|
106
|
+
- You can override the output name (see `outputName`)
|
|
107
|
+
- You can override the output extension (see `outputExt`)
|
|
108
|
+
|
|
109
|
+
#### 2) Single file mode (single-output)
|
|
110
|
+
If `output` **does not end with `/`**, all matched input files are combined into **one** output file.
|
|
111
|
+
|
|
112
|
+
```json
|
|
113
|
+
{
|
|
114
|
+
"input": "src/**/*.ts",
|
|
115
|
+
"output": ".knowhow/docs/ALL.md"
|
|
116
|
+
}
|
|
117
|
+
```
|
|
118
|
+
|
|
119
|
+
---
|
|
120
|
+
|
|
121
|
+
### `prompt` (required or optional depending on your desired behavior)
|
|
122
|
+
Controls the AI instruction template.
|
|
123
|
+
|
|
124
|
+
You can supply `prompt` in any of these ways:
|
|
125
|
+
|
|
126
|
+
1. **Prompt name** (looked up in `promptsDir`)
|
|
127
|
+
```json
|
|
128
|
+
{ "prompt": "BasicCodeDocumenter" }
|
|
129
|
+
```
|
|
130
|
+
The generator looks for:
|
|
131
|
+
- `<promptsDir>/<promptName>.mdx`
|
|
132
|
+
- Default `promptsDir` is: **`.knowhow/prompts`**
|
|
133
|
+
|
|
134
|
+
2. **Direct prompt file path**
|
|
135
|
+
```json
|
|
136
|
+
{ "prompt": "prompts/MyPrompt.mdx" }
|
|
137
|
+
```
|
|
138
|
+
If that file exists, it is read as prompt content.
|
|
139
|
+
|
|
140
|
+
3. **Inline prompt string**
|
|
141
|
+
```json
|
|
142
|
+
{ "prompt": "Summarize the following file as a short doc for newcomers.\n\n{text}" }
|
|
143
|
+
```
|
|
144
|
+
|
|
145
|
+
#### `{text}` placeholder requirement
|
|
146
|
+
If the prompt template does **not** include `{text}`, Knowhow automatically appends:
|
|
147
|
+
|
|
148
|
+
```mdx
|
|
149
|
+
{text}
|
|
150
|
+
```
|
|
151
|
+
|
|
152
|
+
so the input is included when rendering.
|
|
153
|
+
|
|
154
|
+
---
|
|
155
|
+
|
|
156
|
+
### `kind` (optional)
|
|
157
|
+
Controls whether generation is treated as “file generation” or a “special processing kind”.
|
|
158
|
+
|
|
159
|
+
- If `kind` is `"file"` **or missing**, Knowhow performs the normal file summarization flow.
|
|
160
|
+
- Otherwise, Knowhow checks whether `kind` matches a registered plugin:
|
|
161
|
+
- If it is a plugin, the plugin is executed and its returned data is written to `output` (and directory output is rejected for plugin-only output).
|
|
162
|
+
- Then Knowhow still proceeds with file generation for that same source.
|
|
163
|
+
|
|
164
|
+
> In other words: non-`file` kinds can run a plugin and then also run the file-based generation pipeline.
|
|
165
|
+
|
|
166
|
+
---
|
|
167
|
+
|
|
168
|
+
### `agent` (optional)
|
|
169
|
+
Selects which agent to use.
|
|
170
|
+
|
|
171
|
+
- Default agent (as noted in your config requirements): **`Developer`**
|
|
172
|
+
- This value is passed through to summarization functions.
|
|
173
|
+
|
|
174
|
+
---
|
|
175
|
+
|
|
176
|
+
### `model` (optional)
|
|
177
|
+
Overrides the AI model for this source.
|
|
178
|
+
|
|
179
|
+
- If omitted, the summarization functions will use Knowhow’s configured default model/provider logic (outside the code shown here).
|
|
180
|
+
- If provided, the source-specific `model` is used when calling `summarizeFile` / `summarizeFiles`.
|
|
181
|
+
|
|
182
|
+
---
|
|
183
|
+
|
|
184
|
+
### `outputExt` (optional; multi-output mode only)
|
|
185
|
+
Overrides the extension used for generated files when `output` ends with `/`.
|
|
186
|
+
|
|
187
|
+
Default: **`"mdx"`**
|
|
188
|
+
|
|
189
|
+
Example:
|
|
190
|
+
|
|
191
|
+
```json
|
|
192
|
+
{
|
|
193
|
+
"input": "src/**/*.ts",
|
|
194
|
+
"output": ".knowhow/docs/",
|
|
195
|
+
"outputExt": "md"
|
|
196
|
+
}
|
|
197
|
+
```
|
|
198
|
+
|
|
199
|
+
---
|
|
200
|
+
|
|
201
|
+
### `outputName` (optional; multi-output mode only)
|
|
202
|
+
Overrides the generated output file’s base name (instead of using the input file’s name).
|
|
203
|
+
|
|
204
|
+
Example:
|
|
205
|
+
|
|
206
|
+
```json
|
|
207
|
+
{
|
|
208
|
+
"input": "src/**/*.ts",
|
|
209
|
+
"output": ".knowhow/docs/",
|
|
210
|
+
"outputName": "REFERENCE",
|
|
211
|
+
"outputExt": "mdx"
|
|
212
|
+
}
|
|
213
|
+
```
|
|
214
|
+
|
|
215
|
+
Each file would still map into the directory (including nested folders), but each output filename would be `REFERENCE.<outputExt>`.
|
|
216
|
+
|
|
217
|
+
---
|
|
218
|
+
|
|
219
|
+
## Prompt resolution (how Knowhow finds your prompt)
|
|
220
|
+
|
|
221
|
+
Knowhow resolves `source.prompt` using the following order (from `loadPrompt()`):
|
|
222
|
+
|
|
223
|
+
1. **Look in `promptsDir`**
|
|
224
|
+
- Default `promptsDir`: **`.knowhow/prompts`**
|
|
225
|
+
- It checks for:
|
|
226
|
+
`path.join(promptsDir, promptName + ".mdx")`
|
|
227
|
+
|
|
228
|
+
2. **Try `prompt` as a direct file path**
|
|
229
|
+
- If `fs.existsSync(promptName)` succeeds, it reads that file.
|
|
230
|
+
|
|
231
|
+
3. **Treat `prompt` itself as the prompt content**
|
|
232
|
+
- If neither file exists, the value is used as an inline prompt string.
|
|
233
|
+
|
|
234
|
+
Finally, it ensures `{text}` exists (appends it if missing).
|
|
235
|
+
|
|
236
|
+
---
|
|
237
|
+
|
|
238
|
+
## Input → output mapping (output modes)
|
|
239
|
+
|
|
240
|
+
### A) Directory output (`output` ends with `/`)
|
|
241
|
+
For each input file:
|
|
242
|
+
|
|
243
|
+
- Knowhow computes a nested output folder based on the prefix before `**`.
|
|
244
|
+
|
|
245
|
+
Given:
|
|
246
|
+
|
|
247
|
+
```json
|
|
248
|
+
"input": "src/**/*.ts",
|
|
249
|
+
"output": ".knowhow/docs/"
|
|
250
|
+
```
|
|
251
|
+
|
|
252
|
+
- `inputPath` becomes `"src/"` (everything before the `**`)
|
|
253
|
+
- Each input file’s directory is transformed into an equivalent subfolder under the output directory
|
|
254
|
+
|
|
255
|
+
Then each file is written as:
|
|
256
|
+
|
|
257
|
+
- `output/<nestedFolder>/<outputFileName>.<outputExt>`
|
|
258
|
+
|
|
259
|
+
Where:
|
|
260
|
+
- `outputFileName` = `outputName` if provided, otherwise the input file’s base name
|
|
261
|
+
- `outputExt` defaults to `mdx` unless overridden
|
|
262
|
+
|
|
263
|
+
---
|
|
264
|
+
|
|
265
|
+
### B) Single file output (`output` does NOT end with `/`)
|
|
266
|
+
All matched files are combined and written into the one `output` path.
|
|
267
|
+
|
|
268
|
+
---
|
|
269
|
+
|
|
270
|
+
## Hashing / caching behavior (skips unchanged files)
|
|
271
|
+
|
|
272
|
+
Knowhow uses a persistent hash file:
|
|
273
|
+
|
|
274
|
+
- **`.knowhow/.hashes.json`**
|
|
275
|
+
|
|
276
|
+
For each generation operation, it computes:
|
|
277
|
+
|
|
278
|
+
- `promptHash` = `md5(promptString)`
|
|
279
|
+
- `fileHash` = `md5(convertToText(file))` (input content)
|
|
280
|
+
- For directory mode, it checks both:
|
|
281
|
+
- the input file, and
|
|
282
|
+
- the output file
|
|
283
|
+
|
|
284
|
+
If `checkNoFilesChanged()` decides nothing has changed, Knowhow prints a “Skipping…” message and does not regenerate.
|
|
285
|
+
|
|
286
|
+
This means:
|
|
287
|
+
- Changing the prompt will invalidate cache for those files
|
|
288
|
+
- Changing input file content will invalidate cache for those files
|
|
289
|
+
|
|
290
|
+
---
|
|
291
|
+
|
|
292
|
+
## Writing good prompt templates (`.mdx`)
|
|
293
|
+
|
|
294
|
+
Prompt files are typically stored under:
|
|
295
|
+
|
|
296
|
+
- **`.knowhow/prompts/YourPromptName.mdx`**
|
|
297
|
+
|
|
298
|
+
### Minimum guidance
|
|
299
|
+
|
|
300
|
+
- Include a **`{text}`** placeholder somewhere in the prompt.
|
|
301
|
+
- If you forget it, Knowhow will append it automatically at the end—but you should still place it where it makes sense.
|
|
302
|
+
|
|
303
|
+
#### Example: basic prompt file
|
|
304
|
+
|
|
305
|
+
**`.knowhow/prompts/BasicCodeDocumenter.mdx`**
|
|
306
|
+
```mdx
|
|
307
|
+
# Document this file
|
|
308
|
+
|
|
309
|
+
Write a clear developer-focused documentation page.
|
|
310
|
+
|
|
311
|
+
Requirements:
|
|
312
|
+
- 1–2 paragraph summary
|
|
313
|
+
- list of key exported functions/classes
|
|
314
|
+
- notable pitfalls or usage notes
|
|
315
|
+
|
|
316
|
+
Input:
|
|
317
|
+
{text}
|
|
318
|
+
```
|
|
319
|
+
|
|
320
|
+
Then reference it in `knowhow.json`:
|
|
321
|
+
|
|
322
|
+
```json
|
|
323
|
+
{
|
|
324
|
+
"input": "src/**/*.ts",
|
|
325
|
+
"output": ".knowhow/docs/",
|
|
326
|
+
"prompt": "BasicCodeDocumenter"
|
|
327
|
+
}
|
|
328
|
+
```
|
|
329
|
+
|
|
330
|
+
---
|
|
331
|
+
|
|
332
|
+
## Practical examples
|
|
333
|
+
|
|
334
|
+
### 1) Generate docs for every source file (directory mode)
|
|
335
|
+
|
|
336
|
+
```json
|
|
337
|
+
{
|
|
338
|
+
"sources": [
|
|
339
|
+
{
|
|
340
|
+
"input": "src/**/*.ts",
|
|
341
|
+
"output": ".knowhow/docs/",
|
|
342
|
+
"prompt": "BasicCodeDocumenter",
|
|
343
|
+
"outputExt": "mdx",
|
|
344
|
+
"agent": "Developer"
|
|
345
|
+
}
|
|
346
|
+
]
|
|
347
|
+
}
|
|
348
|
+
```
|
|
349
|
+
|
|
350
|
+
Result:
|
|
351
|
+
- `.knowhow/docs/<same-folder-structure-as-src>/<filename>.mdx`
|
|
352
|
+
|
|
353
|
+
---
|
|
354
|
+
|
|
355
|
+
### 2) Generate one “project overview” doc from many inputs (single file mode)
|
|
356
|
+
|
|
357
|
+
```json
|
|
358
|
+
{
|
|
359
|
+
"sources": [
|
|
360
|
+
{
|
|
361
|
+
"input": "src/**/*.ts",
|
|
362
|
+
"output": ".knowhow/docs/OVERVIEW.mdx",
|
|
363
|
+
"prompt": "BasicProjectDocumenter"
|
|
364
|
+
}
|
|
365
|
+
]
|
|
366
|
+
}
|
|
367
|
+
```
|
|
368
|
+
|
|
369
|
+
Result:
|
|
370
|
+
- One file: `.knowhow/docs/OVERVIEW.mdx`
|
|
371
|
+
|
|
372
|
+
---
|
|
373
|
+
|
|
374
|
+
### 3) Use comma-separated input (combined behavior)
|
|
375
|
+
|
|
376
|
+
Comma-separated inputs are treated as brace-expanded patterns, but functionally they still match multiple files.
|
|
377
|
+
|
|
378
|
+
```json
|
|
379
|
+
{
|
|
380
|
+
"sources": [
|
|
381
|
+
{
|
|
382
|
+
"input": "src/a.ts,src/b.ts,src/c.ts",
|
|
383
|
+
"output": ".knowhow/docs/SUBSET.mdx",
|
|
384
|
+
"prompt": "BasicCodeDocumenter"
|
|
385
|
+
}
|
|
386
|
+
]
|
|
387
|
+
}
|
|
388
|
+
```
|
|
389
|
+
|
|
390
|
+
Because `output` does not end with `/`, all matched inputs are combined into **one** output.
|
|
391
|
+
|
|
392
|
+
---
|
|
393
|
+
|
|
394
|
+
### 4) Use brace expansion directly
|
|
395
|
+
|
|
396
|
+
```json
|
|
397
|
+
{
|
|
398
|
+
"sources": [
|
|
399
|
+
{
|
|
400
|
+
"input": "{src/controllers/*.ts,src/services/*.ts}",
|
|
401
|
+
"output": ".knowhow/docs/",
|
|
402
|
+
"prompt": "BasicCodeDocumenter"
|
|
403
|
+
}
|
|
404
|
+
]
|
|
405
|
+
}
|
|
406
|
+
```
|
|
407
|
+
|
|
408
|
+
Directory mode: each input file becomes its own output file.
|
|
409
|
+
|
|
410
|
+
---
|
|
411
|
+
|
|
412
|
+
### 5) Inline prompt (no prompt file)
|
|
413
|
+
|
|
414
|
+
```json
|
|
415
|
+
{
|
|
416
|
+
"sources": [
|
|
417
|
+
{
|
|
418
|
+
"input": "src/index.ts",
|
|
419
|
+
"output": ".knowhow/docs/index.mdx",
|
|
420
|
+
"prompt": "Explain what this module does in plain English.\n\n{text}"
|
|
421
|
+
}
|
|
422
|
+
]
|
|
423
|
+
}
|
|
424
|
+
```
|
|
425
|
+
|
|
426
|
+
---
|
|
427
|
+
|
|
428
|
+
## Pipeline example: generate → embed
|
|
429
|
+
|
|
430
|
+
A common workflow is:
|
|
431
|
+
|
|
432
|
+
1. **Generate documentation files**
|
|
433
|
+
2. **Embed the generated docs** for search/RAG
|
|
434
|
+
|
|
435
|
+
Your config already supports embedding in a separate `embedSources` array. A typical setup:
|
|
436
|
+
|
|
437
|
+
```jsonc
|
|
438
|
+
{
|
|
439
|
+
"sources": [
|
|
440
|
+
{
|
|
441
|
+
"input": "src/**/*.ts",
|
|
442
|
+
"output": ".knowhow/docs/",
|
|
443
|
+
"prompt": "BasicCodeDocumenter"
|
|
444
|
+
}
|
|
445
|
+
],
|
|
446
|
+
"embedSources": [
|
|
447
|
+
{
|
|
448
|
+
"input": ".knowhow/docs/**/*.mdx",
|
|
449
|
+
"output": ".knowhow/embeddings/docs.json",
|
|
450
|
+
"prompt": "BasicEmbeddingExplainer",
|
|
451
|
+
"chunkSize": 2000
|
|
452
|
+
}
|
|
453
|
+
]
|
|
454
|
+
}
|
|
455
|
+
```
|
|
456
|
+
|
|
457
|
+
Then run:
|
|
458
|
+
|
|
459
|
+
```bash
|
|
460
|
+
knowhow generate
|
|
461
|
+
knowhow embed
|
|
462
|
+
```
|
|
463
|
+
|
|
464
|
+
---
|
|
465
|
+
|
|
466
|
+
## Running for specific sources
|
|
467
|
+
|
|
468
|
+
There is **no built-in CLI flag** in the shown `knowhow generate` command to select only one `sources[]` entry.
|
|
469
|
+
|
|
470
|
+
To target a specific source you typically have two options:
|
|
471
|
+
|
|
472
|
+
- **Temporarily edit** `.knowhow/knowhow.json` to comment out other `sources`
|
|
473
|
+
- **Create a separate config** and adjust your workflow (the current CLI wiring shown does not expose a `--config` argument for `generate`)
|
|
474
|
+
|
|
475
|
+
---
|
|
476
|
+
|
|
477
|
+
If you want, paste your current `.knowhow/knowhow.json` `sources` array and tell me whether you want **single-file** or **directory-per-input** outputs—I can help you rewrite it for the behavior you want.
|