refactor: remove hardcoded BUILTIN_* skill string macros

Signed-off-by: Asklv <boironic@gmail.com>
This commit is contained in:
Asklv
2026-02-26 16:00:00 +08:00
parent 729b0f0eb8
commit f8b2a20c7a

View File

@@ -8,98 +8,10 @@
static const char *TAG = "skills"; static const char *TAG = "skills";
/* ── Built-in skill contents ─────────────────────────────────── */ /*
* Built-in skills are now stored as markdown files in spiffs_data/skills/
#define BUILTIN_WEATHER \ * and pre-flashed into the SPIFFS partition at build time.
"# Weather\n" \ */
"\n" \
"Get current weather and forecasts using web_search.\n" \
"\n" \
"## When to use\n" \
"When the user asks about weather, temperature, or forecasts.\n" \
"\n" \
"## How to use\n" \
"1. Use get_current_time to know the current date\n" \
"2. Use web_search with a query like \"weather in [city] today\"\n" \
"3. Extract temperature, conditions, and forecast from results\n" \
"4. Present in a concise, friendly format\n" \
"\n" \
"## Example\n" \
"User: \"What's the weather in Tokyo?\"\n" \
"→ get_current_time\n" \
"→ web_search \"weather Tokyo today February 2026\"\n" \
"→ \"Tokyo: 8°C, partly cloudy. High 12°C, low 4°C. Light wind from the north.\"\n"
#define BUILTIN_DAILY_BRIEFING \
"# Daily Briefing\n" \
"\n" \
"Compile a personalized daily briefing for the user.\n" \
"\n" \
"## When to use\n" \
"When the user asks for a daily briefing, morning update, or \"what's new today\".\n" \
"Also useful as a heartbeat/cron task.\n" \
"\n" \
"## How to use\n" \
"1. Use get_current_time for today's date\n" \
"2. Read " MIMI_SPIFFS_MEMORY_DIR "/MEMORY.md for user preferences and context\n" \
"3. Read today's daily note if it exists\n" \
"4. Use web_search for relevant news based on user interests\n" \
"5. Compile a concise briefing covering:\n" \
" - Date and time\n" \
" - Weather (if location known from USER.md)\n" \
" - Relevant news/updates based on user interests\n" \
" - Any pending tasks from memory\n" \
" - Any scheduled cron jobs\n" \
"\n" \
"## Format\n" \
"Keep it brief — 5-10 bullet points max. Use the user's preferred language.\n"
#define BUILTIN_SKILL_CREATOR \
"# Skill Creator\n" \
"\n" \
"Create new skills for MimiClaw.\n" \
"\n" \
"## When to use\n" \
"When the user asks to create a new skill, teach the bot something, or add a new capability.\n" \
"\n" \
"## How to create a skill\n" \
"1. Choose a short, descriptive name (lowercase, hyphens ok)\n" \
"2. Write a SKILL.md file with this structure:\n" \
" - `# Title` — clear name\n" \
" - Brief description paragraph\n" \
" - `## When to use` — trigger conditions\n" \
" - `## How to use` — step-by-step instructions\n" \
" - `## Example` — concrete example (optional but helpful)\n" \
"3. Save to `" MIMI_SKILLS_PREFIX "<name>.md` using write_file\n" \
"4. The skill will be automatically available after the next conversation\n" \
"\n" \
"## Best practices\n" \
"- Keep skills concise — the context window is limited\n" \
"- Focus on WHAT to do, not HOW (the agent is smart)\n" \
"- Include specific tool calls the agent should use\n" \
"- Test by asking the agent to use the new skill\n" \
"\n" \
"## Example\n" \
"To create a \"translate\" skill:\n" \
"write_file path=\"" MIMI_SKILLS_PREFIX "translate.md\" content=\"# Translate\\n\\nTranslate text between languages.\\n\\n" \
"## When to use\\nWhen the user asks to translate text.\\n\\n" \
"## How to use\\n1. Identify source and target languages\\n" \
"2. Translate directly using your language knowledge\\n" \
"3. For specialized terms, use web_search to verify\\n\"\n"
/* Built-in skill registry */
typedef struct {
const char *filename; /* e.g. "weather" */
const char *content;
} builtin_skill_t;
static const builtin_skill_t s_builtins[] = {
{ "weather", BUILTIN_WEATHER },
{ "daily-briefing", BUILTIN_DAILY_BRIEFING },
{ "skill-creator", BUILTIN_SKILL_CREATOR },
};
#define NUM_BUILTINS (sizeof(s_builtins) / sizeof(s_builtins[0]))
/* ── Install built-in skills if missing ──────────────────────── */ /* ── Install built-in skills if missing ──────────────────────── */