โ† All skills
Tencent SkillHub ยท Developer Tools

Elixir Dev

Elixir/Phoenix development companion. Run and interpret mix test, mix credo, mix dialyzer, mix format. Generate modules following OTP conventions: contexts, schemas, GenServers, supervisors, tasks. Debug compilation errors and warnings. Help with Ecto migrations, queries, changesets, and associations. Use for any Elixir or Phoenix development task including writing modules, fixing tests, refactoring code, or understanding OTP patterns.

skill openclawclawhub Free
0 Downloads
0 Stars
0 Installs
0 Score
High Signal

Elixir/Phoenix development companion. Run and interpret mix test, mix credo, mix dialyzer, mix format. Generate modules following OTP conventions: contexts, schemas, GenServers, supervisors, tasks. Debug compilation errors and warnings. Help with Ecto migrations, queries, changesets, and associations. Use for any Elixir or Phoenix development task including writing modules, fixing tests, refactoring code, or understanding OTP patterns.

โฌ‡ 0 downloads โ˜… 0 stars Unverified but indexed

Install for OpenClaw

Quick setup
  1. Download the package from Yavira.
  2. Extract the archive and review SKILL.md first.
  3. Import or place the package into your OpenClaw setup.

Requirements

Target platform
OpenClaw
Install method
Manual import
Extraction
Extract archive
Prerequisites
OpenClaw
Primary doc
SKILL.md

Package facts

Download mode
Yavira redirect
Package format
ZIP package
Source platform
Tencent SkillHub
What's included
references/mix-commands.md, references/otp-patterns.md, SKILL.md

Validation

  • Use the Yavira download entry.
  • Review SKILL.md after the package is downloaded.
  • Confirm the extracted package contains the expected setup assets.

Install with your agent

Agent handoff

Hand the extracted package to your coding agent with a concrete install brief instead of figuring it out manually.

  1. Download the package from Yavira.
  2. Extract it into a folder your agent can access.
  3. Paste one of the prompts below and point your agent at the extracted folder.
New install

I downloaded a skill package from Yavira. Read SKILL.md from the extracted folder and install it by following the included instructions. Tell me what you changed and call out any manual steps you could not complete.

Upgrade existing

I downloaded an updated skill package from Yavira. Read SKILL.md from the extracted folder, compare it with my current installation, and upgrade it while preserving any custom configuration unless the package docs explicitly say otherwise. Summarize what changed and any follow-up checks I should run.

Trust & source

Release facts

Source
Tencent SkillHub
Verification
Indexed source record
Version
1.0.0

Documentation

ClawHub primary doc Primary doc: SKILL.md 17 sections Open source page

Running Mix Commands

See references/mix-commands.md for full command reference.

Test

# Run all tests mix test # Specific file or line mix test test/my_app/accounts_test.exs:42 # By tag mix test --only integration # Failed only (requires --failed flag from prior run) mix test --failed # With coverage mix test --cover Interpreting failures: ** (MatchError) โ€” Pattern match failed; check return value shape. ** (Ecto.NoResultsError) โ€” Repo.get! with non-existent ID; use Repo.get or seed data. ** (DBConnection.OwnershipError) โ€” Missing async: true or sandbox setup. no function clause matching โ€” Wrong arity or unexpected arg type.

Credo

mix credo --strict mix credo suggest --format json mix credo explain MyApp.Module # Explain issues for specific module Common Credo fixes: Credo.Check.Readability.ModuleDoc โ€” Add @moduledoc. Credo.Check.Refactor.CyclomaticComplexity โ€” Extract helper functions. Credo.Check.Design.TagTODO โ€” Address or remove TODO comments.

Dialyzer

mix dialyzer mix dialyzer --format short Common Dialyzer warnings: The pattern can never match โ€” Dead code or wrong type in pattern. Function has no local return โ€” Crashes on all paths; check internal calls. The call will never return โ€” Calling a function that always raises. Fix: Add @spec annotations; use @dialyzer {:nowarn_function, func: arity} as last resort.

Format

mix format mix format --check-formatted # CI mode โ€” exit 1 if unformatted

Module Generation

Always include @moduledoc, @doc, and @spec on public functions.

Context Module

defmodule MyApp.Notifications do @moduledoc """ Manages notification delivery and preferences. """ import Ecto.Query alias MyApp.Repo alias MyApp.Notifications.Notification @doc "List notifications for a user, most recent first." @spec list_notifications(String.t(), keyword()) :: [Notification.t()] def list_notifications(user_id, opts \\ []) do limit = Keyword.get(opts, :limit, 50) Notification |> where(user_id: ^user_id) |> order_by(desc: :inserted_at) |> limit(^limit) |> Repo.all() end end

Schema Module

defmodule MyApp.Notifications.Notification do @moduledoc """ Schema for push/email/sms notifications. """ use Ecto.Schema import Ecto.Changeset @type t :: %__MODULE__{} @primary_key {:id, :binary_id, autogenerate: true} @foreign_key_type :binary_id @timestamps_opts [type: :utc_datetime_usec] schema "notifications" do field :channel, Ecto.Enum, values: [:push, :email, :sms] field :title, :string field :body, :string field :delivered_at, :utc_datetime_usec field :user_id, :binary_id timestamps() end @required ~w(channel title body user_id)a @doc false def changeset(notification, attrs) do notification |> cast(attrs, @required ++ [:delivered_at]) |> validate_required(@required) |> validate_length(:title, max: 255) end end

OTP Patterns

See references/otp-patterns.md for GenServer, Supervisor, Agent, Task patterns.

When to Use What

PatternUse WhenGenServerStateful process with sync/async calls (cache, rate limiter, connection pool)AgentSimple state wrapper with no complex logicTaskOne-off async work, fire-and-forget or awaitedTask.SupervisorSupervised fire-and-forget tasksSupervisorManaging child process lifecyclesRegistryProcess lookup by name/keyDynamicSupervisorStarting children at runtime

GenServer Template

defmodule MyApp.RateLimiter do @moduledoc "Token bucket rate limiter." use GenServer # Client API def start_link(opts) do name = Keyword.get(opts, :name, __MODULE__) GenServer.start_link(__MODULE__, opts, name: name) end @spec check_rate(String.t()) :: :ok | {:error, :rate_limited} def check_rate(key), do: GenServer.call(__MODULE__, {:check, key}) # Server callbacks @impl true def init(opts) do {:ok, %{limit: Keyword.get(opts, :limit, 100), window_ms: 60_000, buckets: %{}}} end @impl true def handle_call({:check, key}, _from, state) do now = System.monotonic_time(:millisecond) {count, state} = increment(state, key, now) if count <= state.limit, do: {:reply, :ok, state}, else: {:reply, {:error, :rate_limited}, state} end defp increment(state, key, now) do # Implementation end end

Common Compilation Errors

ErrorCauseFixmodule X is not availableMissing dep or typoCheck mix.exs deps, verify module nameundefined function X/NNot imported/aliasedAdd import, alias, or full module path(CompileError) redefining moduleDuplicate module nameRename one of themprotocol not implementedMissing protocol implAdd defimpl for your structcannot use ^x outside of matchPin in wrong positionMove to pattern match context

Dynamic Filters

def list(filters) do Enum.reduce(filters, base_query(), fn {:status, val}, q -> where(q, [r], r.status == ^val) {:since, dt}, q -> where(q, [r], r.inserted_at >= ^dt) {:search, term}, q -> where(q, [r], ilike(r.name, ^"%#{term}%")) _, q -> q end) |> Repo.all() end

Preloading

# Query-time preload (single query with join) from(p in Post, join: a in assoc(p, :author), preload: [author: a]) # Separate query preload Post |> Repo.all() |> Repo.preload(:author) # Nested Repo.preload(posts, [comments: :author])

Aggregates

from(o in Order, where: o.tenant_id == ^tenant_id, group_by: o.status, select: {o.status, count(o.id), sum(o.amount)} ) |> Repo.all()

Mount + Handle Events

defmodule MyAppWeb.DashboardLive do use MyAppWeb, :live_view @impl true def mount(_params, _session, socket) do {:ok, assign(socket, items: [], loading: true)} end @impl true def handle_event("delete", %{"id" => id}, socket) do MyApp.Items.delete_item!(id) {:noreply, assign(socket, items: MyApp.Items.list_items())} end @impl true def render(assigns) do ~H""" <div :for={item <- @items}> <span><%= item.name %></span> <button phx-click="delete" phx-value-id={item.id}>Delete</button> </div> """ end end

PubSub for Real-time

# Subscribe in mount def mount(_, _, socket) do if connected?(socket), do: Phoenix.PubSub.subscribe(MyApp.PubSub, "items") {:ok, assign(socket, items: list_items())} end # Broadcast from context def create_item(attrs) do with {:ok, item} <- %Item{} |> Item.changeset(attrs) |> Repo.insert() do Phoenix.PubSub.broadcast(MyApp.PubSub, "items", {:item_created, item}) {:ok, item} end end # Handle in LiveView def handle_info({:item_created, item}, socket) do {:noreply, update(socket, :items, &[item | &1])} end

Category context

Code helpers, APIs, CLIs, browser automation, testing, and developer operations.

Source: Tencent SkillHub

Largest current source with strong distribution and engagement signals.

Package contents

Included in package
3 Docs
  • SKILL.md Primary doc
  • references/mix-commands.md Docs
  • references/otp-patterns.md Docs