agentvibes 4.2.0 → 4.4.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/.agentvibes/bmad/bmad-voices.md +69 -69
- package/.agentvibes/config.json +12 -0
- package/.claude/activation-instructions +54 -54
- package/.claude/audio/tracks/README.md +52 -52
- package/.claude/commands/agent-vibes/add.md +21 -21
- package/.claude/commands/agent-vibes/agent-vibes.md +101 -101
- package/.claude/commands/agent-vibes/agent.md +79 -79
- package/.claude/commands/agent-vibes/background-music.md +111 -111
- package/.claude/commands/agent-vibes/bmad.md +198 -198
- package/.claude/commands/agent-vibes/clean.md +18 -18
- package/.claude/commands/agent-vibes/cleanup.md +18 -18
- package/.claude/commands/agent-vibes/commands.json +145 -145
- package/.claude/commands/agent-vibes/effects.md +97 -97
- package/.claude/commands/agent-vibes/get.md +9 -9
- package/.claude/commands/agent-vibes/hide.md +91 -91
- package/.claude/commands/agent-vibes/language.md +23 -23
- package/.claude/commands/agent-vibes/learn.md +67 -67
- package/.claude/commands/agent-vibes/list.md +13 -13
- package/.claude/commands/agent-vibes/mute.md +37 -37
- package/.claude/commands/agent-vibes/preview.md +17 -17
- package/.claude/commands/agent-vibes/provider.md +68 -68
- package/.claude/commands/agent-vibes/replay-target.md +14 -14
- package/.claude/commands/agent-vibes/sample.md +12 -12
- package/.claude/commands/agent-vibes/set-favorite-voice.md +84 -84
- package/.claude/commands/agent-vibes/set-pretext.md +65 -65
- package/.claude/commands/agent-vibes/set-speed.md +41 -41
- package/.claude/commands/agent-vibes/show.md +84 -84
- package/.claude/commands/agent-vibes/switch.md +87 -87
- package/.claude/commands/agent-vibes/target-voice.md +26 -26
- package/.claude/commands/agent-vibes/target.md +30 -30
- package/.claude/commands/agent-vibes/translate.md +68 -68
- package/.claude/commands/agent-vibes/unmute.md +45 -45
- package/.claude/commands/agent-vibes/verbosity.md +89 -89
- package/.claude/commands/agent-vibes/whoami.md +7 -7
- package/.claude/commands/agent-vibes-bmad-voices.md +117 -117
- package/.claude/commands/agent-vibes-rdp.md +24 -24
- package/.claude/config/agentvibes.json +1 -0
- package/.claude/config/audio-effects.cfg +2 -2
- package/.claude/config/audio-effects.cfg.sample +52 -52
- package/.claude/config/background-music-volume.txt +1 -0
- package/.claude/config/intro-text.txt +1 -0
- package/.claude/config/piper-speech-rate.txt +4 -0
- package/.claude/config/piper-target-speech-rate.txt +1 -0
- package/.claude/config/reverb-level.txt +1 -0
- package/.claude/config/tts-speech-rate.txt +4 -0
- package/.claude/config/tts-target-speech-rate.txt +1 -0
- package/.claude/docs/TERMUX_SETUP.md +408 -408
- package/.claude/github-star-reminder.txt +1 -1
- package/.claude/hooks/README-TTS-QUEUE.md +135 -135
- package/.claude/hooks/audio-cache-utils.sh +246 -246
- package/.claude/hooks/audio-processor.sh +433 -433
- package/.claude/hooks/background-music-manager.sh +404 -404
- package/.claude/hooks/bmad-speak-enhanced.sh +165 -165
- package/.claude/hooks/bmad-speak.sh +269 -269
- package/.claude/hooks/bmad-tts-injector.sh +568 -568
- package/.claude/hooks/bmad-voice-manager.sh +928 -928
- package/.claude/hooks/clawdbot-receiver-SECURE.sh +129 -129
- package/.claude/hooks/clawdbot-receiver.sh +107 -107
- package/.claude/hooks/clean-audio-cache.sh +22 -22
- package/.claude/hooks/cleanup-cache.sh +106 -106
- package/.claude/hooks/configure-rdp-mode.sh +137 -137
- package/.claude/hooks/download-extra-voices.sh +244 -244
- package/.claude/hooks/effects-manager.sh +268 -268
- package/.claude/hooks/github-star-reminder.sh +154 -154
- package/.claude/hooks/language-manager.sh +362 -362
- package/.claude/hooks/learn-manager.sh +492 -492
- package/.claude/hooks/macos-voice-manager.sh +205 -205
- package/.claude/hooks/migrate-background-music.sh +125 -125
- package/.claude/hooks/migrate-to-agentvibes.sh +161 -161
- package/.claude/hooks/optimize-background-music.sh +87 -87
- package/.claude/hooks/path-resolver.sh +60 -60
- package/.claude/hooks/personality-manager.sh +448 -448
- package/.claude/hooks/piper-download-voices.sh +225 -225
- package/.claude/hooks/piper-installer.sh +292 -292
- package/.claude/hooks/piper-multispeaker-registry.sh +171 -171
- package/.claude/hooks/piper-voice-manager.sh +24 -3
- package/.claude/hooks/play-tts-agentvibes-receiver-for-voiceless-connections.sh +90 -90
- package/.claude/hooks/play-tts-enhanced.sh +105 -105
- package/.claude/hooks/play-tts-macos.sh +368 -368
- package/.claude/hooks/play-tts-piper.sh +679 -679
- package/.claude/hooks/play-tts-soprano.sh +356 -356
- package/.claude/hooks/play-tts-ssh-remote.sh +167 -167
- package/.claude/hooks/play-tts-termux-ssh.sh +169 -169
- package/.claude/hooks/play-tts.sh +301 -301
- package/.claude/hooks/prepare-release.sh +54 -54
- package/.claude/hooks/provider-commands.sh +617 -617
- package/.claude/hooks/provider-manager.sh +399 -399
- package/.claude/hooks/replay-target-audio.sh +95 -95
- package/.claude/hooks/requirements.txt +6 -6
- package/.claude/hooks/sentiment-manager.sh +201 -201
- package/.claude/hooks/session-start-tts.sh +81 -81
- package/.claude/hooks/soprano-gradio-synth.py +139 -139
- package/.claude/hooks/speed-manager.sh +291 -291
- package/.claude/hooks/stop-tts.sh +84 -84
- package/.claude/hooks/termux-installer.sh +261 -261
- package/.claude/hooks/translate-manager.sh +341 -341
- package/.claude/hooks/translator.py +237 -237
- package/.claude/hooks/tts-queue-worker.sh +145 -145
- package/.claude/hooks/tts-queue.sh +165 -165
- package/.claude/hooks/verbosity-manager.sh +178 -178
- package/.claude/hooks/voice-manager.sh +548 -548
- package/.claude/hooks-windows/audio-cache-utils.ps1 +119 -119
- package/.claude/hooks-windows/background-music-manager.ps1 +348 -0
- package/.claude/hooks-windows/clean-audio-cache.ps1 +53 -0
- package/.claude/hooks-windows/download-extra-voices.ps1 +185 -0
- package/.claude/hooks-windows/effects-manager.ps1 +294 -0
- package/.claude/hooks-windows/language-manager.ps1 +193 -0
- package/.claude/hooks-windows/learn-manager.ps1 +241 -0
- package/.claude/hooks-windows/personality-manager.ps1 +266 -0
- package/.claude/hooks-windows/play-tts-piper.ps1 +209 -0
- package/.claude/hooks-windows/play-tts-sapi.ps1 +108 -0
- package/.claude/hooks-windows/play-tts-soprano.ps1 +159 -158
- package/.claude/hooks-windows/play-tts-windows-piper.ps1 +50 -5
- package/.claude/hooks-windows/play-tts-windows-sapi.ps1 +108 -108
- package/.claude/hooks-windows/play-tts.ps1 +344 -266
- package/.claude/hooks-windows/provider-manager.ps1 +29 -10
- package/.claude/hooks-windows/session-start-tts.ps1 +124 -124
- package/.claude/hooks-windows/soprano-gradio-synth.py +153 -153
- package/.claude/hooks-windows/speed-manager.ps1 +166 -0
- package/.claude/hooks-windows/verbosity-manager.ps1 +119 -0
- package/.claude/hooks-windows/voice-manager-windows.ps1 +92 -8
- package/.claude/output-styles/agent-vibes.md +202 -202
- package/.claude/personalities/angry.md +14 -14
- package/.claude/personalities/annoying.md +14 -14
- package/.claude/personalities/crass.md +14 -14
- package/.claude/personalities/dramatic.md +14 -14
- package/.claude/personalities/dry-humor.md +50 -50
- package/.claude/personalities/flirty.md +20 -20
- package/.claude/personalities/funny.md +14 -14
- package/.claude/personalities/grandpa.md +32 -32
- package/.claude/personalities/millennial.md +14 -14
- package/.claude/personalities/moody.md +14 -14
- package/.claude/personalities/normal.md +16 -16
- package/.claude/personalities/pirate.md +14 -14
- package/.claude/personalities/poetic.md +14 -14
- package/.claude/personalities/professional.md +14 -14
- package/.claude/personalities/rapper.md +55 -55
- package/.claude/personalities/robot.md +14 -14
- package/.claude/personalities/sarcastic.md +38 -38
- package/.claude/personalities/sassy.md +14 -14
- package/.claude/personalities/surfer-dude.md +14 -14
- package/.claude/personalities/zen.md +14 -14
- package/.claude/settings.json +15 -15
- package/.claude/verbosity.txt +1 -1
- package/.clawdbot/README.md +105 -105
- package/.clawdbot/skill/SKILL.md +241 -241
- package/.mcp.json +12 -0
- package/CLAUDE.md +170 -170
- package/README.md +2029 -2007
- package/RELEASE_NOTES.md +1310 -1203
- package/WINDOWS-SETUP.md +208 -208
- package/bin/agent-vibes +39 -39
- package/bin/agentvibes-voice-browser.js +1840 -1840
- package/bin/agentvibes.js +48 -2
- package/bin/mcp-server.js +121 -121
- package/bin/mcp-server.sh +206 -206
- package/bin/test-bmad-pr +78 -78
- package/mcp-server/QUICK_START.md +203 -203
- package/mcp-server/README.md +345 -345
- package/mcp-server/WINDOWS_SETUP.md +260 -260
- package/mcp-server/docs/troubleshooting-audio.md +313 -313
- package/mcp-server/examples/claude_desktop_config.json +11 -11
- package/mcp-server/examples/claude_desktop_config_piper.json +9 -9
- package/mcp-server/examples/custom_instructions.md +169 -169
- package/mcp-server/install-deps.js +130 -130
- package/mcp-server/pyproject.toml +52 -52
- package/mcp-server/requirements.txt +2 -2
- package/mcp-server/server.py +1465 -1453
- package/mcp-server/test_server.py +395 -395
- package/mcp-server/test_windows_script_parity.py +336 -0
- package/package.json +110 -110
- package/setup-windows.ps1 +815 -815
- package/src/bmad-detector.js +71 -71
- package/src/cli/list-personalities.js +110 -110
- package/src/cli/list-voices.js +114 -114
- package/src/commands/bmad-voices.js +394 -394
- package/src/commands/install-mcp.js +476 -476
- package/src/console/app.js +824 -824
- package/src/console/audio-env.js +20 -1
- package/src/console/brand-colors.js +13 -13
- package/src/console/constants/personalities.js +44 -44
- package/src/console/footer-config.js +50 -50
- package/src/console/modals/modal-overlay.js +247 -247
- package/src/console/navigation.js +62 -62
- package/src/console/tabs/agents-tab.js +1684 -1516
- package/src/console/tabs/help-tab.js +261 -261
- package/src/console/tabs/install-tab.js +1007 -991
- package/src/console/tabs/music-tab.js +22 -8
- package/src/console/tabs/placeholder-tab.js +53 -53
- package/src/console/tabs/readme-tab.js +267 -267
- package/src/console/tabs/receiver-tab.js +1472 -1212
- package/src/console/tabs/settings-tab.js +208 -84
- package/src/console/tabs/voices-tab.js +100 -21
- package/src/console/widgets/destroy-list.js +25 -25
- package/src/console/widgets/format-utils.js +89 -89
- package/src/console/widgets/notice.js +55 -55
- package/src/console/widgets/personality-picker.js +185 -185
- package/src/console/widgets/reverb-picker.js +94 -94
- package/src/console/widgets/track-picker.js +285 -285
- package/src/installer/music-file-input.js +304 -304
- package/src/installer.js +5895 -5829
- package/src/services/agent-voice-store.js +423 -423
- package/src/services/config-service.js +264 -264
- package/src/services/navigation-service.js +123 -123
- package/src/services/provider-service.js +143 -132
- package/src/services/verbosity-service.js +157 -157
- package/src/utils/audio-duration-validator.js +298 -298
- package/src/utils/audio-format-validator.js +277 -277
- package/src/utils/dependency-checker.js +469 -466
- package/src/utils/file-ownership-verifier.js +358 -358
- package/src/utils/list-formatter.js +194 -194
- package/src/utils/music-file-validator.js +285 -285
- package/src/utils/preview-list-prompt.js +136 -136
- package/src/utils/provider-validator.js +96 -12
- package/src/utils/secure-music-storage.js +412 -412
- package/templates/agentvibes-receiver.sh +482 -482
- package/templates/audio/welcome-music.mp3 +0 -0
- package/voice-assignments.json +8244 -8244
- package/.claude/config/background-music-position.txt +0 -1
|
@@ -1,69 +1,69 @@
|
|
|
1
|
-
---
|
|
2
|
-
plugin: bmad-voices
|
|
3
|
-
version: 2.0.0
|
|
4
|
-
enabled: true
|
|
5
|
-
description: Provider-aware voice mappings for BMAD agents
|
|
6
|
-
---
|
|
7
|
-
|
|
8
|
-
# BMAD Voice Plugin
|
|
9
|
-
|
|
10
|
-
This plugin automatically assigns voices to BMAD agents based on their role and active TTS provider.
|
|
11
|
-
|
|
12
|
-
## Agent Voice Mappings (Provider-Aware)
|
|
13
|
-
|
|
14
|
-
| Agent ID | Agent Name | Intro | Piper TTS Voice | Piper Voice | Personality |
|
|
15
|
-
|----------|------------|-------|------------------|-------------|-------------|
|
|
16
|
-
| pm | John (Product Manager) | John, Product Manager here | Matthew Schmitz | en_US-john-medium | professional |
|
|
17
|
-
| dev | Amelia (Developer) | Amelia, Developer here | Aria | en_US-amy-medium | normal |
|
|
18
|
-
| analyst | Mary (Business Analyst) | Mary, Business Analyst here | Jessica Anne Bogart | en_US-kristin-medium | normal |
|
|
19
|
-
| architect | Winston (Architect) | Winston, Architect here | Michael | en_GB-alan-medium | normal |
|
|
20
|
-
| sm | Bob (Scrum Master) | Bob, Scrum Master here | Matthew Schmitz | en_US-joe-medium | professional |
|
|
21
|
-
| tea | Murat (Test Architect) | Murat, Test Architect here | Michael | en_US-kusal-medium | normal |
|
|
22
|
-
| tech-writer | Paige (Technical Writer) | Paige, Technical Writer here | Aria | en_US-lessac-medium | normal |
|
|
23
|
-
| ux-designer | Sally (UX Designer) | Sally, UX Designer here | Jessica Anne Bogart | en_US-lessac-high | normal |
|
|
24
|
-
| frame-expert | Saif (Visual Designer) | Saif, Visual Designer here | Matthew Schmitz | en_GB-alan-medium | normal |
|
|
25
|
-
| bmad-master | BMad Master | BMad Master here | Michael | en_US-libritts-high | zen |
|
|
26
|
-
| quick-flow-solo-dev | Barry (Quick Flow Solo Dev) | Barry, Quick Flow Solo Dev here | Matthew Schmitz | en_US-john-medium | professional |
|
|
27
|
-
|
|
28
|
-
## How It Works
|
|
29
|
-
|
|
30
|
-
The voice manager automatically selects the appropriate voice based on your active TTS provider:
|
|
31
|
-
- **Piper TTS active**: Uses voices from the "Piper TTS Voice" column
|
|
32
|
-
- **Piper active**: Uses voices from the "Piper Voice" column
|
|
33
|
-
|
|
34
|
-
This ensures BMAD agents work seamlessly regardless of which provider you're using.
|
|
35
|
-
|
|
36
|
-
### Supports Both Display Names and Agent IDs
|
|
37
|
-
|
|
38
|
-
The `bmad-speak.sh` script accepts both formats:
|
|
39
|
-
|
|
40
|
-
**Party Mode** (multiple agents, uses display names):
|
|
41
|
-
```bash
|
|
42
|
-
.claude/hooks/bmad-speak.sh "Winston" "I recommend microservices for scalability"
|
|
43
|
-
```
|
|
44
|
-
|
|
45
|
-
**Individual Agents** (single agent sessions, uses agent IDs):
|
|
46
|
-
```bash
|
|
47
|
-
.claude/hooks/bmad-speak.sh "architect" "I recommend microservices for scalability"
|
|
48
|
-
```
|
|
49
|
-
|
|
50
|
-
Both formats map to the same voice configuration based on the agent ID in the table above. This allows BMAD to use customizable display names while maintaining stable voice mappings.
|
|
51
|
-
|
|
52
|
-
## How to Edit
|
|
53
|
-
|
|
54
|
-
Simply edit the table above to change voice mappings. The format is:
|
|
55
|
-
- **Agent ID**: Must match BMAD's `agent.id` field (pm, dev, qa, etc.)
|
|
56
|
-
- **Agent Name**: Display name (for reference only)
|
|
57
|
-
- **Intro**: Text spoken before agent's message (e.g., "John, Product Manager here"). Leave empty to disable.
|
|
58
|
-
- **Piper TTS Voice**: Voice name for Piper TTS provider
|
|
59
|
-
- **Piper Voice**: Voice model name for Piper provider
|
|
60
|
-
- **Personality**: Optional personality to apply (or "normal" for none)
|
|
61
|
-
|
|
62
|
-
## Commands
|
|
63
|
-
|
|
64
|
-
- `/agent-vibes:bmad enable` - Enable BMAD voice plugin
|
|
65
|
-
- `/agent-vibes:bmad disable` - Disable BMAD voice plugin
|
|
66
|
-
- `/agent-vibes:bmad status` - Show plugin status
|
|
67
|
-
- `/agent-vibes:bmad edit` - Open this file for editing
|
|
68
|
-
- `/agent-vibes:bmad list` - List all agent voice mappings
|
|
69
|
-
- `/agent-vibes:bmad set <agent-id> <piper-voice> <piper-voice> [personality]` - Set voices for specific agent
|
|
1
|
+
---
|
|
2
|
+
plugin: bmad-voices
|
|
3
|
+
version: 2.0.0
|
|
4
|
+
enabled: true
|
|
5
|
+
description: Provider-aware voice mappings for BMAD agents
|
|
6
|
+
---
|
|
7
|
+
|
|
8
|
+
# BMAD Voice Plugin
|
|
9
|
+
|
|
10
|
+
This plugin automatically assigns voices to BMAD agents based on their role and active TTS provider.
|
|
11
|
+
|
|
12
|
+
## Agent Voice Mappings (Provider-Aware)
|
|
13
|
+
|
|
14
|
+
| Agent ID | Agent Name | Intro | Piper TTS Voice | Piper Voice | Personality |
|
|
15
|
+
|----------|------------|-------|------------------|-------------|-------------|
|
|
16
|
+
| pm | John (Product Manager) | John, Product Manager here | Matthew Schmitz | en_US-john-medium | professional |
|
|
17
|
+
| dev | Amelia (Developer) | Amelia, Developer here | Aria | en_US-amy-medium | normal |
|
|
18
|
+
| analyst | Mary (Business Analyst) | Mary, Business Analyst here | Jessica Anne Bogart | en_US-kristin-medium | normal |
|
|
19
|
+
| architect | Winston (Architect) | Winston, Architect here | Michael | en_GB-alan-medium | normal |
|
|
20
|
+
| sm | Bob (Scrum Master) | Bob, Scrum Master here | Matthew Schmitz | en_US-joe-medium | professional |
|
|
21
|
+
| tea | Murat (Test Architect) | Murat, Test Architect here | Michael | en_US-kusal-medium | normal |
|
|
22
|
+
| tech-writer | Paige (Technical Writer) | Paige, Technical Writer here | Aria | en_US-lessac-medium | normal |
|
|
23
|
+
| ux-designer | Sally (UX Designer) | Sally, UX Designer here | Jessica Anne Bogart | en_US-lessac-high | normal |
|
|
24
|
+
| frame-expert | Saif (Visual Designer) | Saif, Visual Designer here | Matthew Schmitz | en_GB-alan-medium | normal |
|
|
25
|
+
| bmad-master | BMad Master | BMad Master here | Michael | en_US-libritts-high | zen |
|
|
26
|
+
| quick-flow-solo-dev | Barry (Quick Flow Solo Dev) | Barry, Quick Flow Solo Dev here | Matthew Schmitz | en_US-john-medium | professional |
|
|
27
|
+
|
|
28
|
+
## How It Works
|
|
29
|
+
|
|
30
|
+
The voice manager automatically selects the appropriate voice based on your active TTS provider:
|
|
31
|
+
- **Piper TTS active**: Uses voices from the "Piper TTS Voice" column
|
|
32
|
+
- **Piper active**: Uses voices from the "Piper Voice" column
|
|
33
|
+
|
|
34
|
+
This ensures BMAD agents work seamlessly regardless of which provider you're using.
|
|
35
|
+
|
|
36
|
+
### Supports Both Display Names and Agent IDs
|
|
37
|
+
|
|
38
|
+
The `bmad-speak.sh` script accepts both formats:
|
|
39
|
+
|
|
40
|
+
**Party Mode** (multiple agents, uses display names):
|
|
41
|
+
```bash
|
|
42
|
+
.claude/hooks/bmad-speak.sh "Winston" "I recommend microservices for scalability"
|
|
43
|
+
```
|
|
44
|
+
|
|
45
|
+
**Individual Agents** (single agent sessions, uses agent IDs):
|
|
46
|
+
```bash
|
|
47
|
+
.claude/hooks/bmad-speak.sh "architect" "I recommend microservices for scalability"
|
|
48
|
+
```
|
|
49
|
+
|
|
50
|
+
Both formats map to the same voice configuration based on the agent ID in the table above. This allows BMAD to use customizable display names while maintaining stable voice mappings.
|
|
51
|
+
|
|
52
|
+
## How to Edit
|
|
53
|
+
|
|
54
|
+
Simply edit the table above to change voice mappings. The format is:
|
|
55
|
+
- **Agent ID**: Must match BMAD's `agent.id` field (pm, dev, qa, etc.)
|
|
56
|
+
- **Agent Name**: Display name (for reference only)
|
|
57
|
+
- **Intro**: Text spoken before agent's message (e.g., "John, Product Manager here"). Leave empty to disable.
|
|
58
|
+
- **Piper TTS Voice**: Voice name for Piper TTS provider
|
|
59
|
+
- **Piper Voice**: Voice model name for Piper provider
|
|
60
|
+
- **Personality**: Optional personality to apply (or "normal" for none)
|
|
61
|
+
|
|
62
|
+
## Commands
|
|
63
|
+
|
|
64
|
+
- `/agent-vibes:bmad enable` - Enable BMAD voice plugin
|
|
65
|
+
- `/agent-vibes:bmad disable` - Disable BMAD voice plugin
|
|
66
|
+
- `/agent-vibes:bmad status` - Show plugin status
|
|
67
|
+
- `/agent-vibes:bmad edit` - Open this file for editing
|
|
68
|
+
- `/agent-vibes:bmad list` - List all agent voice mappings
|
|
69
|
+
- `/agent-vibes:bmad set <agent-id> <piper-voice> <piper-voice> [personality]` - Set voices for specific agent
|
|
@@ -1,54 +1,54 @@
|
|
|
1
|
-
# BMAD Agent Activation Instructions
|
|
2
|
-
|
|
3
|
-
When a BMAD agent activates, follow these steps EXACTLY:
|
|
4
|
-
|
|
5
|
-
## STEP 3.5a: Create BMAD Context File (CRITICAL)
|
|
6
|
-
|
|
7
|
-
**IMMEDIATELY after agent identification, create the context file:**
|
|
8
|
-
|
|
9
|
-
```bash
|
|
10
|
-
echo "$AGENT_ID" > .bmad-agent-context
|
|
11
|
-
```
|
|
12
|
-
|
|
13
|
-
Where `$AGENT_ID` is one of:
|
|
14
|
-
- `pm` (Product Manager)
|
|
15
|
-
- `dev` (Developer)
|
|
16
|
-
- `qa` (QA)
|
|
17
|
-
- `architect` (Architect)
|
|
18
|
-
- `po` (Product Owner)
|
|
19
|
-
- `analyst` (Analyst)
|
|
20
|
-
- `sm` (Scrum Master)
|
|
21
|
-
- `ux-expert` (UX Expert)
|
|
22
|
-
- `bmad-master` (BMAD Master)
|
|
23
|
-
- `bmad-orchestrator` (Orchestrator)
|
|
24
|
-
|
|
25
|
-
**Example:**
|
|
26
|
-
```bash
|
|
27
|
-
# For Product Manager agent
|
|
28
|
-
echo "pm" > .bmad-agent-context
|
|
29
|
-
```
|
|
30
|
-
|
|
31
|
-
This file allows AgentVibes to:
|
|
32
|
-
1. Detect which BMAD agent is active
|
|
33
|
-
2. Look up the correct voice mapping
|
|
34
|
-
3. Automatically speak questions using the agent's assigned voice
|
|
35
|
-
|
|
36
|
-
## STEP 10: Clean Up on Exit
|
|
37
|
-
|
|
38
|
-
**Before exiting the agent, remove the context file:**
|
|
39
|
-
|
|
40
|
-
```bash
|
|
41
|
-
rm -f .bmad-agent-context
|
|
42
|
-
```
|
|
43
|
-
|
|
44
|
-
This ensures voice switching only happens when an agent is active.
|
|
45
|
-
|
|
46
|
-
## Why This Matters
|
|
47
|
-
|
|
48
|
-
Without the `.bmad-agent-context` file:
|
|
49
|
-
- AgentVibes cannot detect which agent is active
|
|
50
|
-
- Questions won't be spoken automatically
|
|
51
|
-
- Voice switching won't work
|
|
52
|
-
- The BMAD voice plugin becomes non-functional
|
|
53
|
-
|
|
54
|
-
**This is MANDATORY for BMAD voice integration to work!**
|
|
1
|
+
# BMAD Agent Activation Instructions
|
|
2
|
+
|
|
3
|
+
When a BMAD agent activates, follow these steps EXACTLY:
|
|
4
|
+
|
|
5
|
+
## STEP 3.5a: Create BMAD Context File (CRITICAL)
|
|
6
|
+
|
|
7
|
+
**IMMEDIATELY after agent identification, create the context file:**
|
|
8
|
+
|
|
9
|
+
```bash
|
|
10
|
+
echo "$AGENT_ID" > .bmad-agent-context
|
|
11
|
+
```
|
|
12
|
+
|
|
13
|
+
Where `$AGENT_ID` is one of:
|
|
14
|
+
- `pm` (Product Manager)
|
|
15
|
+
- `dev` (Developer)
|
|
16
|
+
- `qa` (QA)
|
|
17
|
+
- `architect` (Architect)
|
|
18
|
+
- `po` (Product Owner)
|
|
19
|
+
- `analyst` (Analyst)
|
|
20
|
+
- `sm` (Scrum Master)
|
|
21
|
+
- `ux-expert` (UX Expert)
|
|
22
|
+
- `bmad-master` (BMAD Master)
|
|
23
|
+
- `bmad-orchestrator` (Orchestrator)
|
|
24
|
+
|
|
25
|
+
**Example:**
|
|
26
|
+
```bash
|
|
27
|
+
# For Product Manager agent
|
|
28
|
+
echo "pm" > .bmad-agent-context
|
|
29
|
+
```
|
|
30
|
+
|
|
31
|
+
This file allows AgentVibes to:
|
|
32
|
+
1. Detect which BMAD agent is active
|
|
33
|
+
2. Look up the correct voice mapping
|
|
34
|
+
3. Automatically speak questions using the agent's assigned voice
|
|
35
|
+
|
|
36
|
+
## STEP 10: Clean Up on Exit
|
|
37
|
+
|
|
38
|
+
**Before exiting the agent, remove the context file:**
|
|
39
|
+
|
|
40
|
+
```bash
|
|
41
|
+
rm -f .bmad-agent-context
|
|
42
|
+
```
|
|
43
|
+
|
|
44
|
+
This ensures voice switching only happens when an agent is active.
|
|
45
|
+
|
|
46
|
+
## Why This Matters
|
|
47
|
+
|
|
48
|
+
Without the `.bmad-agent-context` file:
|
|
49
|
+
- AgentVibes cannot detect which agent is active
|
|
50
|
+
- Questions won't be spoken automatically
|
|
51
|
+
- Voice switching won't work
|
|
52
|
+
- The BMAD voice plugin becomes non-functional
|
|
53
|
+
|
|
54
|
+
**This is MANDATORY for BMAD voice integration to work!**
|
|
@@ -1,52 +1,52 @@
|
|
|
1
|
-
# Background Music for AgentVibes
|
|
2
|
-
|
|
3
|
-
This folder contains background music tracks that play behind TTS voice output.
|
|
4
|
-
|
|
5
|
-
## Adding Your Own Music
|
|
6
|
-
|
|
7
|
-
1. **Copy audio files here:**
|
|
8
|
-
```bash
|
|
9
|
-
cp ~/Music/your-track.mp3 .claude/audio/tracks/
|
|
10
|
-
```
|
|
11
|
-
|
|
12
|
-
2. **Edit the config** (`.claude/config/audio-effects.cfg`):
|
|
13
|
-
```
|
|
14
|
-
# Format: AGENT_NAME|SOX_EFFECTS|BACKGROUND_FILE|VOLUME
|
|
15
|
-
|
|
16
|
-
# Party mode (multi-agent discussions)
|
|
17
|
-
_party_mode||your-track.mp3|0.40
|
|
18
|
-
|
|
19
|
-
# Individual agents
|
|
20
|
-
John||electronica.mp3|0.30
|
|
21
|
-
Winston||ambient.mp3|0.25
|
|
22
|
-
```
|
|
23
|
-
|
|
24
|
-
3. **Enable background music:**
|
|
25
|
-
```
|
|
26
|
-
/agent-vibes:background-music on
|
|
27
|
-
```
|
|
28
|
-
|
|
29
|
-
## Supported Formats
|
|
30
|
-
|
|
31
|
-
- MP3 (`.mp3`) - recommended
|
|
32
|
-
- WAV (`.wav`)
|
|
33
|
-
- OGG (`.ogg`)
|
|
34
|
-
|
|
35
|
-
## Tips
|
|
36
|
-
|
|
37
|
-
- **Volume**: Use 0.20-0.40 range (20-40%) so voice stays clear
|
|
38
|
-
- **Track length**: Longer tracks work better (2+ minutes)
|
|
39
|
-
- **Genre**: Instrumental/ambient works best - vocals can compete with TTS
|
|
40
|
-
- **Continuous playback**: Music continues from where it left off between messages
|
|
41
|
-
|
|
42
|
-
## Included Tracks
|
|
43
|
-
|
|
44
|
-
- `dreamy-house.mp3` - Upbeat electronic for energetic agents
|
|
45
|
-
- `agent-vibes-dark-chill-step.mp3` - Atmospheric ambient for party mode
|
|
46
|
-
|
|
47
|
-
## Commands
|
|
48
|
-
|
|
49
|
-
- `/agent-vibes:background-music on` - Enable
|
|
50
|
-
- `/agent-vibes:background-music off` - Disable
|
|
51
|
-
- `/agent-vibes:background-music volume 0.3` - Set volume (0.0-1.0)
|
|
52
|
-
- `/agent-vibes:background-music` - Show status
|
|
1
|
+
# Background Music for AgentVibes
|
|
2
|
+
|
|
3
|
+
This folder contains background music tracks that play behind TTS voice output.
|
|
4
|
+
|
|
5
|
+
## Adding Your Own Music
|
|
6
|
+
|
|
7
|
+
1. **Copy audio files here:**
|
|
8
|
+
```bash
|
|
9
|
+
cp ~/Music/your-track.mp3 .claude/audio/tracks/
|
|
10
|
+
```
|
|
11
|
+
|
|
12
|
+
2. **Edit the config** (`.claude/config/audio-effects.cfg`):
|
|
13
|
+
```
|
|
14
|
+
# Format: AGENT_NAME|SOX_EFFECTS|BACKGROUND_FILE|VOLUME
|
|
15
|
+
|
|
16
|
+
# Party mode (multi-agent discussions)
|
|
17
|
+
_party_mode||your-track.mp3|0.40
|
|
18
|
+
|
|
19
|
+
# Individual agents
|
|
20
|
+
John||electronica.mp3|0.30
|
|
21
|
+
Winston||ambient.mp3|0.25
|
|
22
|
+
```
|
|
23
|
+
|
|
24
|
+
3. **Enable background music:**
|
|
25
|
+
```
|
|
26
|
+
/agent-vibes:background-music on
|
|
27
|
+
```
|
|
28
|
+
|
|
29
|
+
## Supported Formats
|
|
30
|
+
|
|
31
|
+
- MP3 (`.mp3`) - recommended
|
|
32
|
+
- WAV (`.wav`)
|
|
33
|
+
- OGG (`.ogg`)
|
|
34
|
+
|
|
35
|
+
## Tips
|
|
36
|
+
|
|
37
|
+
- **Volume**: Use 0.20-0.40 range (20-40%) so voice stays clear
|
|
38
|
+
- **Track length**: Longer tracks work better (2+ minutes)
|
|
39
|
+
- **Genre**: Instrumental/ambient works best - vocals can compete with TTS
|
|
40
|
+
- **Continuous playback**: Music continues from where it left off between messages
|
|
41
|
+
|
|
42
|
+
## Included Tracks
|
|
43
|
+
|
|
44
|
+
- `dreamy-house.mp3` - Upbeat electronic for energetic agents
|
|
45
|
+
- `agent-vibes-dark-chill-step.mp3` - Atmospheric ambient for party mode
|
|
46
|
+
|
|
47
|
+
## Commands
|
|
48
|
+
|
|
49
|
+
- `/agent-vibes:background-music on` - Enable
|
|
50
|
+
- `/agent-vibes:background-music off` - Disable
|
|
51
|
+
- `/agent-vibes:background-music volume 0.3` - Set volume (0.0-1.0)
|
|
52
|
+
- `/agent-vibes:background-music` - Show status
|
|
@@ -1,21 +1,21 @@
|
|
|
1
|
-
---
|
|
2
|
-
description: Add a new custom Piper TTS TTS voice
|
|
3
|
-
argument-hint: <voice_name> <voice_id>
|
|
4
|
-
---
|
|
5
|
-
|
|
6
|
-
Add a new custom Piper TTS TTS voice to your voice library.
|
|
7
|
-
|
|
8
|
-
Usage:
|
|
9
|
-
- `/agent-vibes:add "My Custom Voice" abc123xyz456789`
|
|
10
|
-
- `/agent-vibes:add Narrator KTPVrSVAEUSJRClDzBw7`
|
|
11
|
-
|
|
12
|
-
The voice ID should be a 15-30 character alphanumeric string from your Piper TTS account.
|
|
13
|
-
|
|
14
|
-
To find your voice IDs:
|
|
15
|
-
1. Go to https://piper.io/app/voice-library
|
|
16
|
-
2. Click on a voice
|
|
17
|
-
3. Copy the voice ID from the URL or settings
|
|
18
|
-
|
|
19
|
-
After adding, you can switch to it with `/agent-vibes:switch "Voice Name"`
|
|
20
|
-
|
|
21
|
-
!bash .claude/hooks/voice-manager.sh add $ARGUMENTS
|
|
1
|
+
---
|
|
2
|
+
description: Add a new custom Piper TTS TTS voice
|
|
3
|
+
argument-hint: <voice_name> <voice_id>
|
|
4
|
+
---
|
|
5
|
+
|
|
6
|
+
Add a new custom Piper TTS TTS voice to your voice library.
|
|
7
|
+
|
|
8
|
+
Usage:
|
|
9
|
+
- `/agent-vibes:add "My Custom Voice" abc123xyz456789`
|
|
10
|
+
- `/agent-vibes:add Narrator KTPVrSVAEUSJRClDzBw7`
|
|
11
|
+
|
|
12
|
+
The voice ID should be a 15-30 character alphanumeric string from your Piper TTS account.
|
|
13
|
+
|
|
14
|
+
To find your voice IDs:
|
|
15
|
+
1. Go to https://piper.io/app/voice-library
|
|
16
|
+
2. Click on a voice
|
|
17
|
+
3. Copy the voice ID from the URL or settings
|
|
18
|
+
|
|
19
|
+
After adding, you can switch to it with `/agent-vibes:switch "Voice Name"`
|
|
20
|
+
|
|
21
|
+
!bash .claude/hooks/voice-manager.sh add $ARGUMENTS
|
|
@@ -1,101 +1,101 @@
|
|
|
1
|
-
---
|
|
2
|
-
description: Piper TTS TTS voice management commands
|
|
3
|
-
---
|
|
4
|
-
|
|
5
|
-
# 🎤 AgentVibes Voice Management
|
|
6
|
-
|
|
7
|
-
Manage your text-to-speech voices across multiple providers (Piper TTS, Piper, macOS Say).
|
|
8
|
-
|
|
9
|
-
## Available Commands
|
|
10
|
-
|
|
11
|
-
### `/agent-vibes:mute`
|
|
12
|
-
Mute all TTS output (persists across sessions)
|
|
13
|
-
- Creates a mute flag that silences all voice output
|
|
14
|
-
- Shows 🔇 indicator when TTS would have played
|
|
15
|
-
|
|
16
|
-
### `/agent-vibes:unmute`
|
|
17
|
-
Unmute TTS output
|
|
18
|
-
- Removes mute flag and restores voice output
|
|
19
|
-
|
|
20
|
-
### `/agent-vibes:list [first|last] [N]`
|
|
21
|
-
List all available voices, with optional filtering
|
|
22
|
-
- `/agent-vibes:list` - Show all voices
|
|
23
|
-
- `/agent-vibes:list first 5` - Show first 5 voices
|
|
24
|
-
- `/agent-vibes:list last 3` - Show last 3 voices
|
|
25
|
-
|
|
26
|
-
### `/agent-vibes:preview [first|last] [N]`
|
|
27
|
-
Preview voices by playing audio samples
|
|
28
|
-
- `/agent-vibes:preview` - Preview first 3 voices
|
|
29
|
-
- `/agent-vibes:preview 5` - Preview first 5 voices
|
|
30
|
-
- `/agent-vibes:preview last 5` - Preview last 5 voices
|
|
31
|
-
|
|
32
|
-
### `/agent-vibes:switch <voice_name>`
|
|
33
|
-
Switch to a different default voice
|
|
34
|
-
- `/agent-vibes:switch Northern Terry`
|
|
35
|
-
- `/agent-vibes:switch "Cowboy Bob"`
|
|
36
|
-
|
|
37
|
-
### `/agent-vibes:get`
|
|
38
|
-
Display the currently selected voice
|
|
39
|
-
|
|
40
|
-
### `/agent-vibes:add <name> <voice_id>`
|
|
41
|
-
Add a new custom voice from your Piper TTS account
|
|
42
|
-
- `/agent-vibes:add "My Voice" abc123xyz456`
|
|
43
|
-
|
|
44
|
-
### `/agent-vibes:replay [N]`
|
|
45
|
-
Replay recently played TTS audio
|
|
46
|
-
- `/agent-vibes:replay` - Replay last audio
|
|
47
|
-
- `/agent-vibes:replay 1` - Replay most recent
|
|
48
|
-
- `/agent-vibes:replay 2` - Replay second-to-last
|
|
49
|
-
- `/agent-vibes:replay 3` - Replay third-to-last
|
|
50
|
-
|
|
51
|
-
Keeps last 10 audio files in history.
|
|
52
|
-
|
|
53
|
-
### `/agent-vibes:set-pretext <word>`
|
|
54
|
-
Set a prefix word/phrase for all TTS messages
|
|
55
|
-
- `/agent-vibes:set-pretext AgentVibes` - All TTS starts with "AgentVibes:"
|
|
56
|
-
- `/agent-vibes:set-pretext "Project Alpha"` - Custom phrase
|
|
57
|
-
- `/agent-vibes:set-pretext ""` - Clear pretext
|
|
58
|
-
|
|
59
|
-
Saved locally in `.agentvibes/config/agentvibes.json`
|
|
60
|
-
|
|
61
|
-
## Provider Management
|
|
62
|
-
|
|
63
|
-
### `/agent-vibes:provider list`
|
|
64
|
-
Show all available TTS providers
|
|
65
|
-
|
|
66
|
-
### `/agent-vibes:provider switch <name>`
|
|
67
|
-
Switch between providers:
|
|
68
|
-
- `/agent-vibes:provider switch piper` - Free, offline (Linux/WSL)
|
|
69
|
-
- `/agent-vibes:provider switch piper` - Premium AI voices
|
|
70
|
-
- `/agent-vibes:provider switch macos` - Native macOS (Mac only)
|
|
71
|
-
|
|
72
|
-
### `/agent-vibes:provider info <name>`
|
|
73
|
-
Get details about a specific provider
|
|
74
|
-
|
|
75
|
-
## Providers
|
|
76
|
-
|
|
77
|
-
| Provider | Platform | Cost | Quality |
|
|
78
|
-
|----------|----------|------|---------|
|
|
79
|
-
| **macOS Say** | macOS only | Free (built-in) | ⭐⭐⭐⭐ |
|
|
80
|
-
| **Piper** | Linux/WSL | Free | ⭐⭐⭐⭐ |
|
|
81
|
-
| **Piper TTS** | All | Free tier + paid | ⭐⭐⭐⭐⭐ |
|
|
82
|
-
|
|
83
|
-
On macOS, the native `say` provider is automatically detected and recommended.
|
|
84
|
-
|
|
85
|
-
## Getting Voice IDs (Piper TTS)
|
|
86
|
-
|
|
87
|
-
To add your own custom Piper TTS voices:
|
|
88
|
-
1. Go to https://piper.io/app/voice-library
|
|
89
|
-
2. Select or create a voice
|
|
90
|
-
3. Copy the voice ID (15-30 character alphanumeric string)
|
|
91
|
-
4. Use `/agent-vibes:add` to add it
|
|
92
|
-
|
|
93
|
-
## Default Voices
|
|
94
|
-
|
|
95
|
-
**Piper TTS:** Northern Terry, Grandpa Spuds Oxley, Ms. Walker, Ralf Eisend, Amy, Michael, Jessica Anne Bogart, Aria, Lutz Laugh, Dr. Von Fusion, Matthew Schmitz, Demon Monster, Cowboy Bob, Drill Sergeant
|
|
96
|
-
|
|
97
|
-
**Piper:** en_US-lessac-medium, en_US-amy-medium, en_GB-alan-medium, and many more
|
|
98
|
-
|
|
99
|
-
**macOS Say:** Samantha, Alex, Daniel, Victoria, Karen, Moira, and 100+ more built-in voices
|
|
100
|
-
|
|
101
|
-
Enjoy your TTS experience! 🎵
|
|
1
|
+
---
|
|
2
|
+
description: Piper TTS TTS voice management commands
|
|
3
|
+
---
|
|
4
|
+
|
|
5
|
+
# 🎤 AgentVibes Voice Management
|
|
6
|
+
|
|
7
|
+
Manage your text-to-speech voices across multiple providers (Piper TTS, Piper, macOS Say).
|
|
8
|
+
|
|
9
|
+
## Available Commands
|
|
10
|
+
|
|
11
|
+
### `/agent-vibes:mute`
|
|
12
|
+
Mute all TTS output (persists across sessions)
|
|
13
|
+
- Creates a mute flag that silences all voice output
|
|
14
|
+
- Shows 🔇 indicator when TTS would have played
|
|
15
|
+
|
|
16
|
+
### `/agent-vibes:unmute`
|
|
17
|
+
Unmute TTS output
|
|
18
|
+
- Removes mute flag and restores voice output
|
|
19
|
+
|
|
20
|
+
### `/agent-vibes:list [first|last] [N]`
|
|
21
|
+
List all available voices, with optional filtering
|
|
22
|
+
- `/agent-vibes:list` - Show all voices
|
|
23
|
+
- `/agent-vibes:list first 5` - Show first 5 voices
|
|
24
|
+
- `/agent-vibes:list last 3` - Show last 3 voices
|
|
25
|
+
|
|
26
|
+
### `/agent-vibes:preview [first|last] [N]`
|
|
27
|
+
Preview voices by playing audio samples
|
|
28
|
+
- `/agent-vibes:preview` - Preview first 3 voices
|
|
29
|
+
- `/agent-vibes:preview 5` - Preview first 5 voices
|
|
30
|
+
- `/agent-vibes:preview last 5` - Preview last 5 voices
|
|
31
|
+
|
|
32
|
+
### `/agent-vibes:switch <voice_name>`
|
|
33
|
+
Switch to a different default voice
|
|
34
|
+
- `/agent-vibes:switch Northern Terry`
|
|
35
|
+
- `/agent-vibes:switch "Cowboy Bob"`
|
|
36
|
+
|
|
37
|
+
### `/agent-vibes:get`
|
|
38
|
+
Display the currently selected voice
|
|
39
|
+
|
|
40
|
+
### `/agent-vibes:add <name> <voice_id>`
|
|
41
|
+
Add a new custom voice from your Piper TTS account
|
|
42
|
+
- `/agent-vibes:add "My Voice" abc123xyz456`
|
|
43
|
+
|
|
44
|
+
### `/agent-vibes:replay [N]`
|
|
45
|
+
Replay recently played TTS audio
|
|
46
|
+
- `/agent-vibes:replay` - Replay last audio
|
|
47
|
+
- `/agent-vibes:replay 1` - Replay most recent
|
|
48
|
+
- `/agent-vibes:replay 2` - Replay second-to-last
|
|
49
|
+
- `/agent-vibes:replay 3` - Replay third-to-last
|
|
50
|
+
|
|
51
|
+
Keeps last 10 audio files in history.
|
|
52
|
+
|
|
53
|
+
### `/agent-vibes:set-pretext <word>`
|
|
54
|
+
Set a prefix word/phrase for all TTS messages
|
|
55
|
+
- `/agent-vibes:set-pretext AgentVibes` - All TTS starts with "AgentVibes:"
|
|
56
|
+
- `/agent-vibes:set-pretext "Project Alpha"` - Custom phrase
|
|
57
|
+
- `/agent-vibes:set-pretext ""` - Clear pretext
|
|
58
|
+
|
|
59
|
+
Saved locally in `.agentvibes/config/agentvibes.json`
|
|
60
|
+
|
|
61
|
+
## Provider Management
|
|
62
|
+
|
|
63
|
+
### `/agent-vibes:provider list`
|
|
64
|
+
Show all available TTS providers
|
|
65
|
+
|
|
66
|
+
### `/agent-vibes:provider switch <name>`
|
|
67
|
+
Switch between providers:
|
|
68
|
+
- `/agent-vibes:provider switch piper` - Free, offline (Linux/WSL)
|
|
69
|
+
- `/agent-vibes:provider switch piper` - Premium AI voices
|
|
70
|
+
- `/agent-vibes:provider switch macos` - Native macOS (Mac only)
|
|
71
|
+
|
|
72
|
+
### `/agent-vibes:provider info <name>`
|
|
73
|
+
Get details about a specific provider
|
|
74
|
+
|
|
75
|
+
## Providers
|
|
76
|
+
|
|
77
|
+
| Provider | Platform | Cost | Quality |
|
|
78
|
+
|----------|----------|------|---------|
|
|
79
|
+
| **macOS Say** | macOS only | Free (built-in) | ⭐⭐⭐⭐ |
|
|
80
|
+
| **Piper** | Linux/WSL | Free | ⭐⭐⭐⭐ |
|
|
81
|
+
| **Piper TTS** | All | Free tier + paid | ⭐⭐⭐⭐⭐ |
|
|
82
|
+
|
|
83
|
+
On macOS, the native `say` provider is automatically detected and recommended.
|
|
84
|
+
|
|
85
|
+
## Getting Voice IDs (Piper TTS)
|
|
86
|
+
|
|
87
|
+
To add your own custom Piper TTS voices:
|
|
88
|
+
1. Go to https://piper.io/app/voice-library
|
|
89
|
+
2. Select or create a voice
|
|
90
|
+
3. Copy the voice ID (15-30 character alphanumeric string)
|
|
91
|
+
4. Use `/agent-vibes:add` to add it
|
|
92
|
+
|
|
93
|
+
## Default Voices
|
|
94
|
+
|
|
95
|
+
**Piper TTS:** Northern Terry, Grandpa Spuds Oxley, Ms. Walker, Ralf Eisend, Amy, Michael, Jessica Anne Bogart, Aria, Lutz Laugh, Dr. Von Fusion, Matthew Schmitz, Demon Monster, Cowboy Bob, Drill Sergeant
|
|
96
|
+
|
|
97
|
+
**Piper:** en_US-lessac-medium, en_US-amy-medium, en_GB-alan-medium, and many more
|
|
98
|
+
|
|
99
|
+
**macOS Say:** Samantha, Alex, Daniel, Victoria, Karen, Moira, and 100+ more built-in voices
|
|
100
|
+
|
|
101
|
+
Enjoy your TTS experience! 🎵
|