blob: 44f33ad5200d6c008452e97a0e07456dd8deee81 [file] [log] [blame]
-module(server).
-include("thrift.hrl").
-include("transport/tSocket.hrl").
-include("protocol/tBinaryProtocol.hrl").
-include("server/tErlServer.hrl").
-include("transport/tErlAcceptor.hrl").
-include("calculator_thrift.hrl").
-export([start/0, start/1, stop/1, ping/0, add/2, calculate/2, getStruct/1, zip/0]).
debug(Format, Data) ->
error_logger:info_msg(Format, Data).
ping() ->
debug("ping()",[]),
ok.
add(N1, N2) ->
debug("add(~p,~p)",[N1,N2]),
N1+N2.
calculate(Logid, Work) ->
{ Op, Num1, Num2 } = { Work#work.op, Work#work.num1, Work#work.num2 },
debug("calculate(~p, {~p,~p,~p})", [Logid, Op, Num1, Num2]),
case Op of
?tutorial_ADD -> Num1 + Num2;
?tutorial_SUBTRACT -> Num1 - Num2;
?tutorial_MULTIPLY -> Num1 * Num2;
?tutorial_DIVIDE when Num2 == 0 ->
throw(#invalidOperation{what=Op, why="Cannot divide by 0"});
?tutorial_DIVIDE ->
Num1 div Num2;
_Else ->
throw(#invalidOperation{what=Op, why="Invalid operation"})
end.
getStruct(Key) ->
debug("getStruct(~p)", [Key]),
#sharedStruct{key=Key, value="RARG"}.
zip() ->
debug("zip", []),
ok.
%%
start() ->
start(9090).
start(Port) ->
thrift:start(),
Handler = ?MODULE,
Processor = calculator_thrift,
TF = tBufferedTransportFactory:new(),
PF = tBinaryProtocolFactory:new(),
ServerTransport = tErlAcceptor,
ServerFlavor = tErlServer,
Server = oop:start_new(ServerFlavor, [Port, Handler, Processor, ServerTransport, TF, PF]),
case ?R0(Server, effectful_serve) of
ok -> Server;
Error -> Error
end.
stop(Server) ->
?C0(Server, stop),
ok.