|  | -module(server). | 
|  |  | 
|  | -include("thrift.hrl"). | 
|  | -include("thrift_logger.hrl"). | 
|  | -include("transport/tSocket.hrl"). | 
|  | -include("protocol/tBinaryProtocol.hrl"). | 
|  |  | 
|  | -include("server/tErlServer.hrl"). | 
|  | -include("transport/tErlAcceptor.hrl"). | 
|  |  | 
|  | -include("calculator.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_logger:install([#thrift_logger_state{ | 
|  | force_one_line = false,         %% should we collapse all errors to one line? | 
|  | term_width = 110,               %% if so, crop output at this width | 
|  | omit = [oop_new, req_processed] %% don't show these kinds of infos | 
|  | }]), | 
|  |  | 
|  | Handler   = ?MODULE, | 
|  | Processor = calculator, | 
|  |  | 
|  | 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. |