[ 
http://issues.apache.org/jira/browse/BEEHIVE-901?page=comments#action_12320602 
] 

Rich Feit commented on BEEHIVE-901:
-----------------------------------

The diff is actually this (moving a loop inside of another loop):

Index: 
compiler-core/org/apache/beehive/netui/compiler/grammar/WebappPathOrActionType.java
===================================================================
--- 
compiler-core/org/apache/beehive/netui/compiler/grammar/WebappPathOrActionType.java
 (revision 264164)
+++ 
compiler-core/org/apache/beehive/netui/compiler/grammar/WebappPathOrActionType.java
 (working copy)
@@ -66,7 +66,7 @@
                 int extensionPos = stringValue.lastIndexOf( 
ACTION_EXTENSION_DOT );
                 String actionMethodName = stringValue.substring( 0, 
extensionPos );
                 FlowControllerInfo fcInfo = getFlowControllerInfo();
-                boolean foundIt = actionExists( actionMethodName, outerType, 
null, getEnv(), fcInfo, false );
+                boolean foundIt = actionExists( actionMethodName, outerType, 
null, getEnv(), fcInfo, true );

                 if ( ! foundIt && actionMethodName.length() > 0 )
                 {
@@ -83,7 +83,7 @@
                         if ( sfTypeDecl != null )
                         {
                             actionMethodName = actionMethodName.substring( dot 
+ 1 );
-                            foundIt = actionExists( actionMethodName, 
sfTypeDecl, null, getEnv(), fcInfo, false );
+                            foundIt = actionExists( actionMethodName, 
sfTypeDecl, null, getEnv(), fcInfo, true );
                         }
                     }
                 }
@@ -146,34 +146,32 @@
                 }
             }

-            ClassType superType = classDecl.getSuperclass();
-            classDecl = superType != null ? 
superType.getClassTypeDeclaration() : null;
-        } while ( classDecl != null );
-
-        //
-        // Next, look through the simple actions (annotations).
-        //
-        MergedControllerAnnotation mca = 
fcInfo.getMergedControllerAnnotation();
-        Collection simpleActionAnnotations =
-                checkInheritedActions
-                ? mca.getSimpleActions()
-                : CompilerUtils.getAnnotationArrayValue( type, 
CONTROLLER_TAG_NAME, SIMPLE_ACTIONS_ATTR, true );
-
-        if ( simpleActionAnnotations != null )
-        {
-            for ( Iterator ii = simpleActionAnnotations.iterator(); 
ii.hasNext(); )
+            //
+            // Next, look through the simple actions (annotations).
+            //
+            Collection simpleActionAnnotations =
+                CompilerUtils.getAnnotationArrayValue( classDecl, 
CONTROLLER_TAG_NAME, SIMPLE_ACTIONS_ATTR, true );
+
+            if ( simpleActionAnnotations != null )
             {
-                AnnotationInstance ann = ( AnnotationInstance ) ii.next();
-                String name = CompilerUtils.getString( ann, NAME_ATTR, false );
-
-                if ( actionName.equals( name )
-                     && ! CompilerUtils.annotationsAreEqual( ann, 
annotationToIgnore, false, env ) )
+                for ( Iterator i = simpleActionAnnotations.iterator(); 
i.hasNext(); )
                 {
-                    return true;
+                    AnnotationInstance ann = ( AnnotationInstance ) i.next();
+                    String name = CompilerUtils.getString( ann, NAME_ATTR, 
false );
+
+                    if ( actionName.equals( name )
+                            && ! CompilerUtils.annotationsAreEqual( ann, 
annotationToIgnore, false, env ) )
+                    {
+                        return true;
+                    }
                 }
             }
-        }
+
+            ClassType superType = classDecl.getSuperclass();
+            classDecl = superType != null ? 
superType.getClassTypeDeclaration() : null;
+        } while ( checkInheritedActions && classDecl != null );

+
         return false;
     }
 }

> Cannot forward to an inherited simple action
> --------------------------------------------
>
>          Key: BEEHIVE-901
>          URL: http://issues.apache.org/jira/browse/BEEHIVE-901
>      Project: Beehive
>         Type: Bug
>   Components: NetUI
>     Versions: v1m1
>     Reporter: Rich Feit
>     Assignee: Rich Feit
>      Fix For: V1

>
> Repro:
> Create and build the following page flow controllers:
> ---
> @Jpf.Controller(
>     simpleActions={
>         @Jpf.SimpleAction(name="simpleAction", path="index.jsp")
>     }
> )
> public abstract class BaseController extends PageFlowController
> {
> }
> ---
> @Jpf.Controller(
>     simpleActions={
>         @Jpf.SimpleAction(name="begin", action="simpleAction")
>     }
> )
> public class DerivedController extends BaseController
> {
> }
> ---
> EXPECTED: compiles file
> ACTUAL: get the following error:
>       [apt] 
> C:\temp\todelete\inherit\WEB-INF\.tmpbeansrc\pageFlowCore\inheritActions\derived\Controller.java:14:
>  Action "simpleAction" was not found.
>       [apt] public class Controller extends 
> pageFlowCore.inheritActions.base.Controller
>       [apt]        ^
>       [apt] 1 error

-- 
This message is automatically generated by JIRA.
-
If you think it was sent incorrectly contact one of the administrators:
   http://issues.apache.org/jira/secure/Administrators.jspa
-
For more information on JIRA, see:
   http://www.atlassian.com/software/jira

Reply via email to