Version 1.1 of ai12s/ai12-0169-1.txt
!standard 9.5.2(5) 15-06-17 AI05-0169-1/01
!class binding interpretation 15-06-17
!status work item 15-06-17
!status received 15-06-05
!priority Low
!difficulty Easy
!qualifier Omission
!subject Aspect specifications for entry bodies
!summary
Aspect specifications are allowed on entry bodies (for implementation-defined
aspects).
!question
Ada syntax allows an aspect_specification to occur in 37 different contexts,
but an entry_body isn't one of them.
This seems like it was just an oversight. The permission for
implementation-defined aspects doesn't allow putting aspect_specifications
in new places. We need an implementation-defined aspect for SPARK on entry
bodies.
Should this be changed? (Yes.)
!recommendation
(See Summary.)
!wording
Replace 9.5.2(5) by:
entry_body ::=
entry defining_identifier entry_body_formal_part
[aspect_specification]
entry_barrier is
declarative_part
begin
handled_sequence_of_statements
end [entry_identifier];
[Editor's note: The only change here is the addition of an optional
aspect_specification. We never describe syntax changes with insertion and
deletion brackets, because those are legal syntax descriptors and it is
impossible to tell which is meant.]
!discussion
Toward the end of the Ada 2012 effort, we decided to add aspect_specification
to all bodies, as we thought that it might be useful to specify
implementation-defined aspects there. However, we failed to do that for entry
bodies; that seems like a clear oversight.
The location of the aspect_specification is as proposed. This is an
inconsistent location; for all other bodies, the aspect specification goes
directly before the IS.
There a couple of reasons for this: reasonable aspects may affect the
entry_barrier, so it seemed appropriate for it to precede the entry barrier.
And there isn't really a definition of "header" -- one could see the
entry_barrier as part of the body rather than the specification. After all,
it doesn't appear as part of the entry declaration.
The AI author doesn't buy this; this aspect_specification will be little-used
and putting it in a non-standard place will be a continual annoyance (just
as having the aspect_specification after "is abstract" and "is null" is an
annoyance, because one always puts it before the "is" and then gets a syntax
error, then looks up the syntax again, then moves it to the right place.
Repeat ad-nausem).
In the e-mail, there also was a suggestion aspects are better first because
the entry barrier might be very long ("running on several lines"). But of
course some aspects could also be "very long" (that's certainly true of Pre
and Post), and arguably it would be best to put these things in order of
importance. That is, having the barrier (which is critical to the Ada
semantics) after a bunch of implementation-defined glop (which is
not part of the Ada semantics) seems like an inversion.
[Editor's note: Of course this isn't a big deal, I just find that I agree
with J-P on this topic. And unlike null procedures and expression functions
(where the importance of "is null" and the like is clearly higher than any
aspect specification), it seems that all of the arguments point to putting
it directly before the IS.]
!ASIS
No ASIS effect.
!ACATS test
No ACATS test is possible until/unless there is a language defined aspect
allowed on entry bodies.
!appendix
From: Steve Baird
Sent: Thursday, June 4, 2015 4:18 PM
Hopefully this one is a simple, non-controversial change.
Ada syntax allows an aspect_specification to occur in
37 different contexts, but an entry_body isn't one of them.
This seems like it was just an oversight and now SPARK needs this capability.
It does not seem that the 13.1.1 permissions
The aspect_specification for an implementation-defined aspect may use
an implementation-defined syntax for the aspect_definition, and may
follow implementation-defined legality and semantics rules.
help in this case.
So the following one-line grammar change is proposed:
!wording
Modify 9.5.2(5)
entry_body ::=
ENTRY defining_identifier entry_body_formal_part
{ [aspect_specification] }
entry_barrier IS
declarative_part
begin
handled_sequence_of_statements
end [entry_identifier];
****************************************************************
From: Jean-Pierre Rosen
Sent: Friday, June 5, 2015 3:42 AM
Shouldn't the aspect_specification be after the entry_barrier?
Normally, aspects are stuck at the end, here it would appear in the middle
of the header.
****************************************************************
From: Tucker Taft
Sent: Friday, June 5, 2015 7:29 AM
We debated that. At least in our use, the aspects may affect the
entry_barrier, so it seemed appropriate for it to precede the entry barrier.
And there isn't really a definition of "header" -- one could see the
entry_barrier as part of the body rather than the specification. After all,
it doesn't appear as part of the entry declaration.
I agree it isn't totally obvious, and either could work.
****************************************************************
From: Tullio Vardanega
Sent: Friday, June 5, 2015 7:51 AM
If, as it seems to be the intent, the aspect should affect the entry barrier,
then it should be logical that the aspect spec precedes the barrier spec.
****************************************************************
From: Tucker Taft
Sent: Friday, June 5, 2015 7:59 AM
I might add that in some of my uses of entry barriers, they can be very
complex, running on for several lines. It feels like it would be better for
aspect specifications to precede all of that.
****************************************************************
Questions? Ask the ACAA Technical Agent