Pure templates + name conversions behind mix mob.new_plugin.
Inputs are a snake_case plugin name (e.g. "mob_demo_widget") and a tier
(0–4). Output is a list of {relative_path, content_string} pairs the Mix
task writes to disk. All conversions live here so the task stays thin and
the templates are unit-testable without filesystem I/O.
Templates mirror the on-device-verified prototypes (mob_palette_demo t0,
mob_demo_haptic_extras t1, mob_demo_signature_pad t2,
mob_demo_kv_browser t3, mob_demo_subapp t4) so a freshly scaffolded plugin
compiles + activates by the same path the prototypes already prove.
Summary
Functions
Returns the file list for a given tier + name. Each entry is
{relative_path, content}. relative_path is relative to the plugin's
root directory.
Converts "mob_demo_widget" → "MobDemoWidget".
Validates a plugin name (must be a snake_case atom-friendly identifier).
Validates a tier (0 through 4).
Types
Functions
Returns the file list for a given tier + name. Each entry is
{relative_path, content}. relative_path is relative to the plugin's
root directory.
Converts "mob_demo_widget" → "MobDemoWidget".
Validates a plugin name (must be a snake_case atom-friendly identifier).
Validates a tier (0 through 4).