From: Niklas Holsti <niklas.holsti@tidorum.invalid>
Subject: Re: What makes a procedure call 'dispatching' in Ada?
Date: Fri, 20 Nov 2009 16:10:54 +0200
Date: 2009-11-20T16:10:54+02:00 [thread overview]
Message-ID: <4b06a394$0$6270$4f793bc4@news.tdc.fi> (raw)
In-Reply-To: <Pine.LNX.4.64.0911201018540.19682@medsec1.medien.uni-weimar.de>
> On Fri, 20 Nov 2009, Markus Schoepflin wrote:
>
>
>> ---%<---
>> package FOOS is
>>
>> type FOO is abstract tagged null record;
>>
>> procedure P (THIS : in FOO);
>
> -------> replace by
> procedure P (THIS : in FOO'Class);
>
>> procedure A (THIS : in FOO) is abstract;
>>
>> end FOOS;
>>
>> package body FOOS is
>>
>> procedure P (THIS : in FOO)
>
> -------> replace by
> procedure P (THIS : in FOO'Class);
>
>> is
>> begin
>> A (THIS);
>> end;
>>
>> end FOOS;
>> --->%---
>>
>> When trying to compile this, I get:
>>
>> foos.adb:6:07: call to abstract function must be dispatching
>> gnatmake: "foos.adb" compilation error
>>
>> What is the compiler trying to tell me here? And how do I go
>> about calling abstract procedures?
>>
>> TIA,
>> Markus
stefan-lucks@see-the.signature wrote:
> If Foo is a tagged type, then
> "procedure A(This: [in] [out] Foo)"
>
> expects *exactly* the same type as the actual parameter. If you want
> "either type Foo or any of its object-oriented children" you write
>
> "procedure B(This: [in] [out] Foo'Class)".
>
> In your case, Foo is an abstract tagged type. As much as I seem to
> understand Ada, there is no way to actually call procedure A -- because
> you can't have any actuals of an abstract type. (Hey you guys out there,
> am I wrong?)
There is no way to call A on an object of (apparent) type FOO because A
is declared as abstract for FOO. The compiler very correctly says that
such a call is impossible.
But you can call the overriding (concrete) implementation of A for the
actual type of THIS (some non-abstract type derived from FOO) by
converting to class-wide to force dispatching:
A (FOO'Class (THIS));
> If I am right, it is very regrettable that the compiler doesn't issue a
> warning when compiling "procedure A(This: [in] [out] Foo)" for an abstract
> type Foo ... perhaps better, a revised Ada should prohibit that.
There is no reason for such a warning because defining A in this way is
legal and useful, as long as you convert the parameter to FOO'Class when
you call it. You can consider the name A (of the abstract operation) a
kind of place-holder for all the concrete implementations of A for
derived types.
But Dmitry probably thinks that there should be warning of the form "Bad
design! Naughty!" :-)
--
Niklas Holsti
Tidorum Ltd
niklas holsti tidorum fi
. @ .
next prev parent reply other threads:[~2009-11-20 14:10 UTC|newest]
Thread overview: 18+ messages / expand[flat|nested] mbox.gz Atom feed top
2009-11-20 13:15 What makes a procedure call 'dispatching' in Ada? Markus Schoepflin
2009-11-20 9:31 ` stefan-lucks
2009-11-20 14:10 ` Niklas Holsti [this message]
2009-11-20 13:27 ` Dmitry A. Kazakov
2009-11-20 13:43 ` Markus Schoepflin
2009-11-20 13:54 ` RasikaSrinivasan@gmail.com
2009-11-20 13:58 ` Markus Schoepflin
2009-11-20 14:19 ` Niklas Holsti
2009-11-21 14:07 ` Peter C. Chapin
2009-11-20 14:00 ` Niklas Holsti
2009-11-20 14:10 ` Dmitry A. Kazakov
2009-11-20 13:56 ` Niklas Holsti
2009-11-20 14:31 ` Dmitry A. Kazakov
2009-11-20 15:00 ` Niklas Holsti
2009-11-20 18:44 ` Dmitry A. Kazakov
2009-11-20 20:09 ` Niklas Holsti
2009-11-20 20:59 ` Dmitry A. Kazakov
2009-11-20 14:54 ` Ludovic Brenta
replies disabled
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox