CVS difference for arm/source/03c.mss

Differences between 1.24 and version 1.25
Log of other versions for file arm/source/03c.mss

--- arm/source/03c.mss	2005/05/05 00:45:29	1.24
+++ arm/source/03c.mss	2005/05/07 05:18:23	1.25
@@ -1,9 +1,9 @@
 @Part(03, Root="ada.mss")
-@Comment{$Date: 2005/05/05 00:45:29 $}
+@Comment{$Date: 2005/05/07 05:18:23 $}
 @Comment{$Source: e:\\cvsroot/ARM/Source/03c.mss,v $}
-@Comment{$Revision: 1.24 $}
+@Comment{$Revision: 1.25 $}
 @LabeledClause{Tagged Types and Type Extensions}
@@ -707,7 +707,7 @@
 corresponding to the tag@Chg{Version=[2],New=[ or external tag],Old=[]} passed
 as a parameter exists in the partition at the time the function is called.
 In most implementations,
 repeated elaborations of the same@Chg{Version=[2],New=[ non-extension],Old=[]}
 @nt{type_declaration} will all produce the same tag.
@@ -718,8 +718,8 @@
 for each elaboration of a @nt{type_declaration}.@Chg{Version=[2],New=[ (This is
 required if the type is derived from a type at a shallower level.)],Old=[]}
 In that case, Tag_Error could also be raised if the created type
-longer exists because the subprogram containing it has returned,
-for example.
+no longer exists because the subprogram
+containing it has returned, for example.
 We don't require the latter behavior@Chg{Version=[2],New=[ for non-library-level
 types],Old=[]}; hence the word @lquotes@;may@rquotes@; in this rule.
@@ -2226,6 +2226,11 @@
     [@key{limited} | @key{task} | @key{protected} | @key{synchronized}] @key{interface} [@key{and} @Syn2{interface_list}]>,Old=<>}"}
+rhs="@Chg{Version=[2],New=<@SynI{interface_}@Syn2{subtype_mark} {@key{and} @SynI{interface_}@Syn2{subtype_mark}}>,Old=<>}"}
@@ -2277,13 +2282,21 @@
 derived from interfaces.]}
 @Chg{Version=[2],New=[@Redundant[An interface type has no components.]],Old=[]}
    @ChgAdded{Version=[2],Text=[This follows from the syntax.]}
+@ChgAdded{Version=[2],Text=[@Defn{progenitor subtype}@Defn{progenitor type}
+An @Syni(interface_)@nt{subtype_mark} in an @nt{interface_list} names a
+@i(progenitor subtype); its type is the @i(progenitor type).
+An interface type inherits user-defined primitive subprograms from each
+progenitor type in the same way that a derived type inherits user-defined
+primitive subprograms from its progenitor types
+(see @RefSecNum{Derived Types and Classes}).]}

Questions? Ask the ACAA Technical Agent