summaryrefslogtreecommitdiff
path: root/lib/poolparty/pool/worker.ex
blob: 5ae41612b223d34025b49131b5a187b3c74390e3 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
defmodule PoolParty.Pool.Worker do
  use GenServer
  require Logger

  def start_link(opts \\ []) do
    Logger.debug("[#{__MODULE__}]: Starting worker")
    GenServer.start_link(__MODULE__, {}, opts)
  end

  def init(_) do
    Logger.debug("[#{__MODULE__}]: Initializing Worker")
    PoolParty.Scheduler.join(self)
    {:ok, nil}
  end

  def process(pid, function, args) do
    Logger.debug("[#{__MODULE__}: Casting Process request")
    GenServer.cast(pid, {:compute, function, args})
  end

  def handle_cast({:compute, function, args}, _) do
    Logger.debug("[#{__MODULE__}]: Process request received")
    PoolParty.Scheduler.ready({:result, function.(args), self})
    {:noreply, nil}
  end

end