summaryrefslogtreecommitdiff
path: root/tutorial/cl/make-tutorial-client.lisp
blob: 3a6d86134fd13632db7817846f2e996719e47662 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
(in-package #:cl-user)

;;;; Licensed under the Apache License, Version 2.0 (the "License");
;;;; you may not use this file except in compliance with the License.
;;;; You may obtain a copy of the License at
;;;;
;;;;     http://www.apache.org/licenses/LICENSE-2.0
;;;;
;;;; Unless required by applicable law or agreed to in writing, software
;;;; distributed under the License is distributed on an "AS IS" BASIS,
;;;; WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
;;;; See the License for the specific language governing permissions and
;;;; limitations under the License.

(require "asdf")
(load (merge-pathnames "load-locally.lisp" *load-truename*))
(asdf:load-system :net.didierverna.clon)
(asdf:load-asd (merge-pathnames "gen-cl/shared/thrift-gen-shared.asd" *load-truename*))
(asdf:load-asd (merge-pathnames "gen-cl/tutorial/thrift-gen-tutorial.asd" *load-truename*))
(asdf:load-asd (merge-pathnames "thrift-tutorial.asd" *load-truename*))
(asdf:load-system :thrift-tutorial)

(net.didierverna.clon:nickname-package)

(defun main ()
  "Entry point for the binary."
  (thrift:with-client (prot #u"thrift://127.0.0.1:9090")
    (tutorial.calculator:ping prot)
    (format t "ping()~%")
    (format t "1 + 1 = ~a~%" (tutorial.calculator:add prot 1 1))
    (let ((work-instance (tutorial:make-work :num1 5
                                             :num2 0
                                             :op tutorial:operation.divide
                                             :comment "Booya!")))
      (handler-case (format t
                            "5 / 0 = ~a - Oh, really? An exception should have been thrown here.~%"
                            (tutorial.calculator:calculate prot 1 work-instance))
        (tutorial:invalidoperation (e)
          (format t "---~%(Expected) Invalid Operation caught: ~%~a~%---~%" e))))
    (let ((work-instance (tutorial:make-work :num1 15
                                             :num2 10
                                             :op tutorial:operation.subtract
                                             :comment "Playing nice this time.")))
      (handler-case (format t
                            "15 - 10 = ~a~%"
                            (tutorial.calculator:calculate prot 1 work-instance))
        (tutorial:invalidoperation (e)
          (format t "---~%(Unexpected) Invalid Operation caught: ~%~a~%---~%" e))))
    (format t "Check log: ~a~%" (shared.shared-service:get-struct prot 1))))

(clon:dump "TutorialClient" main)