aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorkballou <kballou@devnulllabs.io>2016-10-31 00:11:43 -0600
committerkballou <kballou@devnulllabs.io>2016-10-31 00:11:43 -0600
commit6ce4db4dfa1a5a137a83e4f7f56340a763d23fee (patch)
tree27619a81e0ef6301bb1595ba6592b530a1113f1f
parent62b532d0f0236bf91451c7e4bacacc34799caaa6 (diff)
downloadoctochat-6ce4db4dfa1a5a137a83e4f7f56340a763d23fee.tar.gz
octochat-6ce4db4dfa1a5a137a83e4f7f56340a763d23fee.tar.xz
Add better error handling to echo read_linev0.2.1
-rw-r--r--lib/octochat/servers/echo.ex13
-rw-r--r--mix.exs2
2 files changed, 10 insertions, 5 deletions
diff --git a/lib/octochat/servers/echo.ex b/lib/octochat/servers/echo.ex
index fe25079..da04876 100644
--- a/lib/octochat/servers/echo.ex
+++ b/lib/octochat/servers/echo.ex
@@ -2,18 +2,23 @@ defmodule Octochat.Echo do
@moduledoc """
Octochat Echo server
"""
+ require Logger
def serve(socket) do
socket
- |> read_line!()
+ |> read_line()
|> write_line!(socket)
serve(socket)
end
- defp read_line!(socket) do
- {:ok, line} = :gen_tcp.recv(socket, 0)
- line
+ defp read_line(socket) do
+ case :gen_tcp.recv(socket, 0) do
+ {:ok, line} -> line
+ {:error, reason} ->
+ Logger.error(reason)
+ Process.exit(self, :normal)
+ end
end
defp write_line!(line, socket) do
diff --git a/mix.exs b/mix.exs
index ff25c44..b504c69 100644
--- a/mix.exs
+++ b/mix.exs
@@ -5,7 +5,7 @@ defmodule Octochat.Mixfile do
[app: :octochat,
description: "Demo Application for How Swapping Code",
package: package(),
- version: "0.2.0",
+ version: "0.2.1",
elixir: "~> 1.3",
build_embedded: Mix.env == :prod,
start_permanent: Mix.env == :prod,