Package org.drools.reteoo

Source Code of org.drools.reteoo.AlphaNetworkCompiler

package org.drools.reteoo;

import java.util.Arrays;
import java.util.Comparator;

import org.drools.util.Iterator;
import org.drools.util.ObjectHashMap;
import org.drools.util.ObjectHashMap.ObjectEntry;

public class AlphaNetworkCompiler {
    private StringBuilder builder;

    public void compile(ObjectTypeNode objectTypeNode) {
        builder = new StringBuilder();
        builder.append( "public class Compiled" + objectTypeNode.getObjectType() + "AlphaNetwork implements ObjectSink { \n" );
       
        createVars( objectTypeNode.getSinkPropagator().getSinks(), );
       
        builder.append( "    public void assertObject(....) { \n");

        compileAlphaNodes( objectTypeNode.getSinkPropagator(),
                           8 );
       
        builder.append( "    } \n" );
        builder.append( "} \n" );

        System.out.println( builder.toString() );
    }

    public void createVars(ObjectSink[] sinks,
                           int indent) {
        for ( ObjectSink sink : sinks ) {
            if ( sink instanceof AlphaNode ) {
                AlphaNode alphaNode = (AlphaNode) sink;
                builder.append( getIndent( indent ) + "AlphaNodeFieldConstraint alphaNodeConstraint" + alphaNode.getId() + ";\n" );
                createVars( alphaNode.getSinkPropagator().getSinks(), indent );
            } else if ( sink instanceof BetaNode ) {
                BetaNode betaNode = (BetaNode) sink;
                builder.append( getIndent( indent ) "ObjectSink sink" + betaNode.getId() + ";\n" );
            } else if ( sink instanceof LeftInputAdapterNode ) {
                LeftInputAdapterNode liaNode = (LeftInputAdapterNode) sink;
                builder.append( getIndent( indent ) "ObjectSink sink" + liaNode.getId() + ";\n" );
            }
        }
    }

    public void compileAlphaNodes(ObjectSinkPropagator adapter,
                                  int indent) {
        if ( adapter instanceof SingleObjectSinkAdapter ) {
            compileAlphaNodeSingleConstraint( (SingleObjectSinkAdapter) adapter,
                                              indent );
        } else if ( adapter instanceof CompositeObjectSinkAdapter ) {
            compileAlphaNodeCompositeConstraint( (CompositeObjectSinkAdapter) adapter,
                                                 indent );
        }
    }

    private void compileAlphaNodeCompositeConstraint(CompositeObjectSinkAdapter adapter,
                                                     int indent) {
        ObjectSinkNodeList sinks = adapter.getHashableSinks();
        if ( sinks != null ) {
            for ( ObjectSinkNode sink = sinks.getFirst(); sink != null; sink = sink.getNextObjectSinkNode() ) {
                compileAlphaNodeSingleConstraint( sink,
                                                  indent );
            }
        }

        sinks = adapter.getOthers();
        if ( sinks != null ) {
            for ( ObjectSinkNode sink = sinks.getFirst(); sink != null; sink = sink.getNextObjectSinkNode() ) {
                compileAlphaNodeSingleConstraint( sink,
                                                  indent );
            }
        }

        ObjectHashMap map = adapter.getHashedSinkMap();
        if ( map != null ) {
            ObjectEntry[] entries = new ObjectEntry[map.size()];
            Iterator it = map.iterator();
            int i = 0;
            for ( ObjectEntry entry = (ObjectEntry) it.next(); entry != null; entry = (ObjectEntry) it.next() ) {
                entries[i++] = entry;
            }

            // we sort as switch works faster with ordered cases
            Arrays.sort( entries,
                         new Comparator() {
                             public int compare(Object o1,
                                                Object o2) {
                                 ObjectEntry entry1 = (ObjectEntry) o1;
                                 ObjectEntry entry2 = (ObjectEntry) o2;
                                 return ((ObjectSink) entry1.getValue()).getId() - ((ObjectSink) entry2.getValue()).getId();
                             }

                         } );

            //final Iterator it = map.newIterator();
            builder.append( getIndent( indent ) + "HashKey key = new HashKey(handle);\n" );
            builder.append( getIndent( indent ) + "swtich ((ObjectSink)this.hashedSinkedMap(key)).getId() {\n" );
            for ( ObjectEntry entry : entries ) {
                ObjectSink sink = (ObjectSink) entry.getValue();
                builder.append( getIndent( indent + 4 ) + "case " + sink.getId() + ": {\n" );
                //builder.append( getIndent( indent + 8 ) + "sink" + sink.getId() + ".assertRight(handle, wm, context);\n" );
               
                if (sink instanceof AlphaNode ) {
                    compileAlphaNodes( ((AlphaNode)sink).getSinkPropagator(),
                                       indent + 8 );                   
                }
               
                builder.append( getIndent( indent + 4 )+ "};\n" );
            }
            builder.append( getIndent( indent ) + "};\n" );
        }

    }

    public void compileAlphaNodeSingleConstraint(SingleObjectSinkAdapter adapter,
                                                 int indent) {
        compileAlphaNodeSingleConstraint( adapter.getSinks()[0],
                                          indent );
    }

    public void compileAlphaNodeSingleConstraint(ObjectSink sink,
                                                 int indent) {
        if ( sink instanceof AlphaNode ) {
            AlphaNode alphaNode = (AlphaNode) sink;
            builder.append( getIndent( indent ) + "if ( alphaNodeConstraint" + alphaNode.getId() + ".isAllowed(handle, wm) ) {\n" );
            compileAlphaNodes( alphaNode.getSinkPropagator(),
                               indent + 4 );
            builder.append( getIndent( indent ) + "}\n" );
        } else if ( sink instanceof BetaNode ) {
            BetaNode betaNode = (BetaNode) sink;
            builder.append( getIndent( indent ) + "sink" + betaNode.getId() + ".assertRight(handle, wm, context);\n" );
        } else if ( sink instanceof LeftInputAdapterNode ) {
            LeftInputAdapterNode liaNode = (LeftInputAdapterNode) sink;
            builder.append( getIndent( indent ) + "sink" + liaNode.getId() + ".assertRight(handle, wm, context);\n" );
        }
    }

    public void compileAlphaNodeCompositeConstraint(ObjectSink sink,
                                                    int indent) {
        if ( sink instanceof AlphaNode ) {
            AlphaNode alphaNode = (AlphaNode) sink;
            builder.append( getIndent( indent ) + "if ( alphaNodeConstraint" + alphaNode.getId() + ".isAllowed(handle, wm) ) {\n" );
            compileAlphaNodes( alphaNode.getSinkPropagator(),
                               indent + 4 );
            builder.append( getIndent( indent ) + "}\n" );
        } else if ( sink instanceof BetaNode ) {
            BetaNode betaNode = (BetaNode) sink;
            builder.append( getIndent( indent ) + "sink" + betaNode.getId() + ".assertRight(handle, wm, context);\n" );
        } else if ( sink instanceof LeftInputAdapterNode ) {
            LeftInputAdapterNode liaNode = (LeftInputAdapterNode) sink;
            builder.append( getIndent( indent ) + "sink" + liaNode.getId() + ".assertRight(handle, wm, context);\n" );
        }
    }

    private String getIndent(int indent) {
        char[] spaces = new char[indent];
        for ( int i = 0; i < spaces.length; i++ ) {
            spaces[i] = ' ';
        }

        return new String( spaces );
    }

}
TOP

Related Classes of org.drools.reteoo.AlphaNetworkCompiler

TOP
Copyright © 2018 www.massapi.com. All rights reserved.
All source code are property of their respective owners. Java is a trademark of Sun Microsystems, Inc and owned by ORACLE Inc. Contact coftware#gmail.com.