c-parse.in (methodtype): New production.
authorNeil Booth <neil@daikokuya.demon.co.uk>
Wed, 16 May 2001 06:34:34 +0000 (06:34 +0000)
committerNeil Booth <neil@gcc.gnu.org>
Wed, 16 May 2001 06:34:34 +0000 (06:34 +0000)
* c-parse.in (methodtype): New production.
(methoddef, methodproto): Collapse separate '-' and '+'
handlers into 1.

From-SVN: r42133

gcc/ChangeLog
gcc/c-parse.in

index b44b60af1306f905530252c12580d06759ba8b2d..70561097d88b882660066fdf1bfcd27a69454b64 100644 (file)
@@ -1,3 +1,9 @@
+2001-05-16  Neil Booth  <neil@daikokuya.demon.co.uk>
+
+       * c-parse.in (methodtype): New production.
+       (methoddef, methodproto): Collapse separate '-' and '+'
+       handlers into 1.
+
 2001-05-16  Neil Booth  <neil@cat.daikokuya.demon.co.uk>
 
        * c-common.h (RID_FIRST_PQ): New.
index cee2637e89fcccf8e13b54e40dcb9c6fb7703aed..3eda45c25de454ef926bc84abd034146ce375240 100644 (file)
@@ -2947,44 +2947,27 @@ ivar_declarator:
                 }
        ;
 
-methoddef:
+methodtype:
          '+'
-               {
-                 objc_pq_context = 1;
-                 if (objc_implementation_context)
-                   objc_inherit_code = CLASS_METHOD_DECL;
-                  else
-                   fatal_error ("method definition not in class context");
-               }
-         methoddecl
-               {
-                 objc_pq_context = 0;
-                 add_class_method (objc_implementation_context, $3);
-                 start_method_def ($3);
-                 objc_method_context = $3;
-               }
-         optarglist
-               {
-                 continue_method_def ();
-               }
-         compstmt_or_error
-               {
-                 finish_method_def ();
-                 objc_method_context = NULL_TREE;
-               }
-
+               { objc_inherit_code = CLASS_METHOD_DECL; }
        | '-'
+               { objc_inherit_code = INSTANCE_METHOD_DECL; }
+       ;
+
+methoddef:
+         methodtype
                {
                  objc_pq_context = 1;
-                 if (objc_implementation_context)
-                   objc_inherit_code = INSTANCE_METHOD_DECL;
-                  else
+                 if (!objc_implementation_context)
                    fatal_error ("method definition not in class context");
                }
          methoddecl
                {
                  objc_pq_context = 0;
-                 add_instance_method (objc_implementation_context, $3);
+                 if (objc_inherit_code == CLASS_METHOD_DECL)
+                   add_class_method (objc_implementation_context, $3);
+                 else
+                   add_instance_method (objc_implementation_context, $3);
                  start_method_def ($3);
                  objc_method_context = $3;
                }
@@ -3021,31 +3004,19 @@ semi_or_error:
        ;
 
 methodproto:
-         '+'
+         methodtype
                {
                  /* Remember protocol qualifiers in prototypes.  */
                  objc_pq_context = 1;
-                 objc_inherit_code = CLASS_METHOD_DECL;
                }
          methoddecl
                {
                  /* Forget protocol qualifiers here.  */
                  objc_pq_context = 0;
-                 add_class_method (objc_interface_context, $3);
-               }
-         semi_or_error
-
-       | '-'
-               {
-                 /* Remember protocol qualifiers in prototypes.  */
-                 objc_pq_context = 1;
-                 objc_inherit_code = INSTANCE_METHOD_DECL;
-               }
-         methoddecl
-               {
-                 /* Forget protocol qualifiers here.  */
-                 objc_pq_context = 0;
-                 add_instance_method (objc_interface_context, $3);
+                 if (objc_inherit_code == CLASS_METHOD_DECL)
+                   add_class_method (objc_interface_context, $3);
+                 else
+                   add_instance_method (objc_interface_context, $3);
                }
          semi_or_error
        ;