Changeset 3579


Ignore:
Timestamp:
09/04/03 14:42:53 (20 years ago)
Author:
piso
Message:

divideBy(): catch ArithmeticException? (division by zero).

File:
1 edited

Legend:

Unmodified
Added
Removed
  • trunk/j/src/org/armedbear/lisp/Fixnum.java

    r3570 r3579  
    33 *
    44 * Copyright (C) 2002-2003 Peter Graves
    5  * $Id: Fixnum.java,v 1.60 2003-09-04 04:28:01 piso Exp $
     5 * $Id: Fixnum.java,v 1.61 2003-09-04 14:42:53 piso Exp $
    66 *
    77 * This program is free software; you can redistribute it and/or
     
    281281    public LispObject divideBy(LispObject obj) throws LispError
    282282    {
    283         if (obj instanceof Fixnum) {
    284             final int divisor = ((Fixnum)obj).value;
    285             if (value % divisor == 0)
    286                 return new Fixnum(value / divisor);
    287             return number(BigInteger.valueOf(value),
    288                           BigInteger.valueOf(divisor));
    289         }
    290         if (obj instanceof Bignum)
    291             return number(getBigInteger(), ((Bignum)obj).getValue());
    292         if (obj instanceof Ratio) {
    293             BigInteger numerator = ((Ratio)obj).numerator();
    294             BigInteger denominator = ((Ratio)obj).denominator();
    295             return number(getBigInteger().multiply(denominator),
    296                           numerator);
    297         }
    298         if (obj instanceof LispFloat)
    299             return new LispFloat(value / LispFloat.getValue(obj));
    300         if (obj instanceof Complex) {
    301             Complex c = (Complex) obj;
    302             LispObject realPart = c.getRealPart();
    303             LispObject imagPart = c.getImaginaryPart();
    304             LispObject denominator =
    305                 realPart.multiplyBy(realPart).add(imagPart.multiplyBy(imagPart));
    306             return Complex.getInstance(multiplyBy(realPart).divideBy(denominator),
    307                                        Fixnum.ZERO.subtract(multiplyBy(imagPart).divideBy(denominator)));
    308         }
    309         throw new TypeError(obj, "number");
     283        try {
     284            if (obj instanceof Fixnum) {
     285                final int divisor = ((Fixnum)obj).value;
     286                if (value % divisor == 0)
     287                    return new Fixnum(value / divisor);
     288                return number(BigInteger.valueOf(value),
     289                              BigInteger.valueOf(divisor));
     290            }
     291            if (obj instanceof Bignum)
     292                return number(getBigInteger(), ((Bignum)obj).getValue());
     293            if (obj instanceof Ratio) {
     294                BigInteger numerator = ((Ratio)obj).numerator();
     295                BigInteger denominator = ((Ratio)obj).denominator();
     296                return number(getBigInteger().multiply(denominator),
     297                              numerator);
     298            }
     299            if (obj instanceof LispFloat)
     300                return new LispFloat(value / LispFloat.getValue(obj));
     301            if (obj instanceof Complex) {
     302                Complex c = (Complex) obj;
     303                LispObject realPart = c.getRealPart();
     304                LispObject imagPart = c.getImaginaryPart();
     305                LispObject denominator =
     306                    realPart.multiplyBy(realPart).add(imagPart.multiplyBy(imagPart));
     307                return Complex.getInstance(multiplyBy(realPart).divideBy(denominator),
     308                                           Fixnum.ZERO.subtract(multiplyBy(imagPart).divideBy(denominator)));
     309            }
     310            throw new TypeError(obj, "number");
     311        }
     312        catch (ArithmeticException e) {
     313            if (obj.zerop())
     314                throw new DivisionByZero();
     315            throw new ArithmeticError(e.getMessage());
     316        }
    310317    }
    311318
Note: See TracChangeset for help on using the changeset viewer.