aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorNathan Lasseter <nathan.je.lasseter@googlemail.com>2011-01-28 22:13:57 +0000
committerNathan Lasseter <nathan.je.lasseter@googlemail.com>2011-01-28 22:13:57 +0000
commitf2c818015f711aaca7a7c1add7101c48effcfd54 (patch)
tree22cfbaecdec48213edf7c4a260755f14d40caeeb
parent5bc3f93d9d3804af72ade9b4d5cd896f3b432cf4 (diff)
no more noarg and some cleaning
-rw-r--r--TODO.textile1
-rw-r--r--erlbal.erl27
2 files changed, 3 insertions, 25 deletions
diff --git a/TODO.textile b/TODO.textile
index 5a67ed4..9707d08 100644
--- a/TODO.textile
+++ b/TODO.textile
@@ -3,7 +3,6 @@ h1. TODO
h2. Little changes:
* Add server state
-* Remove the argless request call and implement strict listed args
h2. BIG changes:
diff --git a/erlbal.erl b/erlbal.erl
index 5f599dc..84830a7 100644
--- a/erlbal.erl
+++ b/erlbal.erl
@@ -1,7 +1,7 @@
-module(erlbal).
--export([make_request/1, make_request/2, start_bal/0, stop_bal/1, start_server/3, stop_server/2, list_servers/1]).
+-export([make_request/2, start_bal/0, stop_bal/1, start_server/3, stop_server/2, list_servers/1]).
-start_server(Balancer, Node, Fun) ->
+start_server(Balancer, Node, Fun) when is_function(Fun, 1) ->
PID = spawn(Node, fun() -> server_loop(Fun) end),
Balancer ! {add_node, PID}.
@@ -15,10 +15,6 @@ list_servers(Balancer) ->
server_loop(Fun) ->
receive
- {request, From} ->
- Ret = Fun(),
- From ! Ret,
- server_loop(Fun);
{request, From, ARGS} ->
Ret = Fun(ARGS),
From ! Ret,
@@ -42,17 +38,6 @@ bal_loop(Serverlist, Nextserver) ->
{list_nodes, From} ->
From ! Serverlist,
bal_loop(Serverlist, Nextserver);
- {request, From} ->
- Serv = lists:nth(Nextserver, Serverlist),
- Serv ! {request, From},
- NS = Nextserver + 1,
- SLL = length(Serverlist),
- if
- NS > SLL ->
- bal_loop(Serverlist, 1);
- true ->
- bal_loop(Serverlist, NS)
- end;
{request, From, ARGS} ->
Serv = lists:nth(Nextserver, Serverlist),
Serv ! {request, From, ARGS},
@@ -64,17 +49,11 @@ bal_loop(Serverlist, Nextserver) ->
true ->
bal_loop(Serverlist, NS)
end;
- {response, To, Ret} ->
- To ! Ret,
- bal_loop(Serverlist, Nextserver);
die ->
lists:foreach(fun(X) -> X ! die end, Serverlist)
end.
-make_request(Balancer) ->
- Balancer ! {request, self()},
- receive Ret -> Ret end.
-make_request(Balancer, ARGS) ->
+make_request(Balancer, ARGS) when is_list(ARGS)->
Balancer ! {request, self(), ARGS},
receive Ret -> Ret end.