Sha256: 1a45dec2054e7061e07edb4e79a0517b7912970cb1ae86be5233216193aaae24

Contents?: true

Size: 1.31 KB

Versions: 3

Compression:

Stored size: 1.31 KB

Contents

defmodule BankAccount do
  @moduledoc """
  A bank account that supports access from multiple processes.
  """

  use GenServer

  ## Callbacks

  def init(_args) do
    { :ok, 0 }
  end

  def handle_call(:balance, _from, balance) do
    { :reply, balance, balance }
  end

  def handle_call({ :update, amount }, _from, balance) do
    { :reply, :ok, balance + amount }
  end

  def handle_call(:close, _from, balance) do
    # We stop normally and return :stopped to the caller.
    { :stop, :normal, :stopped, balance }
  end

  ## Interface for tests

  @typedoc """
  An account handle.
  """
  @opaque account :: pid

  @doc """
  Open the bank. Makes the account available.
  """
  @spec open_bank() :: account
  def open_bank() do
    { :ok, pid } = :gen_server.start_link(BankAccount, [], [])
    pid
  end

  @doc """
  Close the bank. Makes the account unavailable.
  """
  @spec close_bank(account) :: none
  def close_bank(account) do
    :gen_server.call(account, :close)
  end

  @doc """
  Get the account's balance.
  """
  @spec balance(account) :: integer
  def balance(account) do
    :gen_server.call(account, :balance)
  end

  @doc """
  Update the account's balance by adding the given amount which may be negative.
  """
  def update(account, amount) do
    :gen_server.call(account, { :update, amount })
  end
end

Version data entries

3 entries across 3 versions & 1 rubygems

Version Path
trackler-1.0.1.0 tracks/elixir/exercises/bank-account/example.exs
trackler-1.0.0.1 tracks/elixir/exercises/bank-account/example.exs
trackler-1.0.0 tracks/elixir/exercises/bank-account/example.exs