From mboxrd@z Thu Jan 1 00:00:00 1970 X-Spam-Checker-Version: SpamAssassin 3.4.4 (2020-01-24) on polar.synack.me X-Spam-Level: * X-Spam-Status: No, score=1.3 required=5.0 tests=BAYES_00,INVALID_MSGID, MSGID_RANDY autolearn=no autolearn_force=no version=3.4.4 X-Google-Language: ENGLISH,ASCII-7-bit X-Google-Thread: 103376,c5ca2cbae60e9fee X-Google-Attributes: gid103376,public From: Ehud Lamm Subject: Re: OO puzzle Date: 1999/12/23 Message-ID: <83sqht$5oi$1@nnrp1.deja.com>#1/1 X-Deja-AN: 564075911 References: <83qtap$pri$1@nnrp1.deja.com> X-Http-Proxy: 1.0 o-proxy.cc.huji.ac.il:8080 (Squid/2.2.STABLE4), 1.0 x21.deja.com:80 (Squid/1.1.22) for client 132.64.12.88, 132.64.1.34 Organization: Deja.com - Before you buy. X-Article-Creation-Date: Thu Dec 23 09:38:22 1999 GMT X-MyDeja-Info: XMYDJUIDehudlamm Newsgroups: comp.lang.ada X-Http-User-Agent: Mozilla/4.0 (compatible; MSIE 5.0; Windows 95) Date: 1999-12-23T00:00:00+00:00 List-Id: In article <83qtap$pri$1@nnrp1.deja.com>, Ted Dennison wrote: > In article > Well, I'll assume in Ada you would be talking about a routine that > takes in driver'class and also has a "motor_vehicle" parameter on which > it dispatches, and it does *not* dispatch on the driver. One possibility > would be to have truck's version of register_driver internally check > that the driver is in truck_driver'class: > > if d not in truck_driver'class then > raise Constraint_Error; > end if; > Right. But than we are dealing with a runtime check. See the discussion per Tucker's post. > Another would be to disallow calls to the original register altogether > (via "abstract" perhaps?) and to make a new one that only takes in > truck_driver'class. That looses the dynamic dispatch from > Motor_Vehicle'class, though. But than you lose the ability to define the abstract interface (for Motor_Vehicle) and know that it is supported by all descendants. Trade offs all arround... -- Ehud Lamm mslamm@mscc.huji.ac.il http://purl.oclc.org/NET/ehudlamm Check it out and subscribe to the E-List Sent via Deja.com http://www.deja.com/ Before you buy.