File: tutorial-implementation.lisp

package info (click to toggle)
thrift 0.13.0-6
  • links: PTS
  • area: main
  • in suites: bullseye
  • size: 27,652 kB
  • sloc: cpp: 91,805; cs: 25,285; ansic: 18,752; java: 18,097; pascal: 13,604; javascript: 9,419; python: 8,875; ruby: 8,361; erlang: 6,408; php: 6,008; sh: 5,463; makefile: 3,995; perl: 3,335; haskell: 2,952; xml: 1,019; yacc: 1,010; ml: 962; lisp: 644; lex: 337
file content (41 lines) | stat: -rw-r--r-- 1,704 bytes parent folder | download | duplicates (4)
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
(in-package #:tutorial-implementation)

;;;; 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.

(defun tutorial.calculator-implementation:ping ()
  (format t "ping()~%"))

(defun tutorial.calculator-implementation:add (num1 num2)
  (format t "add(~a, ~a)~%" num1 num2)
  (+ num1 num2))

(defun tutorial.calculator-implementation:calculate (logid work)
  (format t "calculate(~a, ~a)~%" logid work)
  (handler-case
      (let* ((num1 (tutorial:work-num1 work))
             (num2 (tutorial:work-num2 work))
             (op (tutorial:work-op work))
             (result
              (cond
                ((= op tutorial:operation.add) (+ num1 num2))
                ((= op tutorial:operation.subtract) (- num1 num2))
                ((= op tutorial:operation.multiply) (* num1 num2))
                ((= op tutorial:operation.divide) (/ num1 num2)))))
        (shared-implementation::add-log logid result)
        result)
    (division-by-zero () (error 'tutorial:invalidoperation
                                :why "Division by zero."
                                :what-op (tutorial:work-op work)))))

(defun tutorial.calculator-implementation:zip ()
  (format t "zip()~%"))