📄 joinnode.java
字号:
package org.drools.reteoo;
/*
* Copyright 2005 JBoss Inc
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
import java.util.ArrayList;
import java.util.HashMap;
import java.util.Iterator;
import java.util.List;
import java.util.Map;
import org.drools.common.BetaNodeBinder;
import org.drools.common.DefaultFactHandle;
import org.drools.spi.PropagationContext;
/**
* <code>JoinNode</code> extends <code>BetaNode</code> to perform
* <code>ReteTuple</code> and <code>FactHandle</code> joins. Tuples are
* considered to be asserted from the left input and facts from the right input.
* The <code>BetaNode</code> provides the BetaMemory to store assserted
* ReteTuples and
* <code>FactHandleImpl<code>s. Each fact handle is stored in the right memory as a key in a <code>HashMap</code>, the value is an <code>ObjectMatches</code>
* instance which maintains a <code>LinkedList of <code>TuplesMatches - The tuples that are matched with the handle. the left memory is a <code>LinkedList</code>
* of <code>ReteTuples</code> which maintains a <code>HashMa</code>, where the keys are the matching <code>FactHandleImpl</code>s and the value is
* populated <code>TupleMatche</code>es, the keys are matched fact handles. <code>TupleMatch</code> maintains a <code>List</code> of resulting joins,
* where there is joined <code>ReteTuple</code> per <code>TupleSink</code>.
*
*
* The BetaNode provides
* the BetaMemory which stores the
*
* @see BetaNode
* @see ObjectMatches
* @see TupleMatch
* @see TupleSink
*
* @author <a href="mailto:mark.proctor@jboss.com">Mark Proctor</a>
* @author <a href="mailto:bob@werken.com">Bob McWhirter</a>
*
*/
class JoinNode extends BetaNode {
// ------------------------------------------------------------
// Instance methods
// ------------------------------------------------------------
/**
*
*/
private static final long serialVersionUID = 4075809540597599706L;
/**
* Construct.
*
* @param leftInput
* The left input <code>TupleSource</code>.
* @param rightInput
* The right input <code>TupleSource</code>.
*/
JoinNode(final int id,
final TupleSource leftInput,
final ObjectSource rightInput) {
super( id,
leftInput,
rightInput );
}
JoinNode(final int id,
final TupleSource leftInput,
final ObjectSource rightInput,
final BetaNodeBinder binder) {
super( id,
leftInput,
rightInput,
binder );
}
/**
* Assert a new <code>ReteTuple</code>. The right input of
* <code>FactHandleInput</code>'s is iterated and joins attemped, via the
* binder, any successful bindings results in joined tuples being created
* and propaged. there is a joined tuple per TupleSink.
*
* @see ReteTuple
* @see ObjectMatches
* @see TupleSink
* @see TupleMatch
*
* @param tuple
* The <code>Tuple</code> being asserted.
* @param context
* The <code>PropagationContext</code>
* @param workingMemory
* The working memory seesion.
*/
public void assertTuple(final ReteTuple leftTuple,
final PropagationContext context,
final ReteooWorkingMemory workingMemory) {
final BetaMemory memory = (BetaMemory) workingMemory.getNodeMemory( this );
memory.add( workingMemory,
leftTuple );
final BetaNodeBinder binder = getJoinNodeBinder();
for ( final Iterator it = memory.rightObjectIterator( workingMemory,
leftTuple ); it.hasNext(); ) {
final ObjectMatches objectMatches = (ObjectMatches) it.next();
final DefaultFactHandle handle = objectMatches.getFactHandle();
final TupleMatch tupleMatch = attemptJoin( leftTuple,
handle,
objectMatches,
binder,
workingMemory );
if ( tupleMatch != null ) {
propagateAssertTuple( new ReteTuple( leftTuple,
handle ),
tupleMatch,
context,
workingMemory );
}
}
}
/**
* Assert a new <code>FactHandleImpl</code>. The left input of
* <code>ReteTuple</code>s is iterated and joins attemped, via the
* binder, any successful bindings results in joined tuples being created
* and propaged. there is a joined tuple per TupleSink.
*
* @see ReteTuple
* @see ObjectMatches
* @see TupleSink
* @see TupleMatch
*
* @param handle
* The <code>FactHandleImpl</code> being asserted.
* @param context
* The <code>PropagationContext</code>
* @param workingMemory
* The working memory seesion.
*/
public void assertObject(final DefaultFactHandle handle,
final PropagationContext context,
final ReteooWorkingMemory workingMemory) {
final BetaMemory memory = (BetaMemory) workingMemory.getNodeMemory( this );
final ObjectMatches objectMatches = memory.add( workingMemory,
handle );
final BetaNodeBinder binder = getJoinNodeBinder();
for ( final Iterator it = memory.leftTupleIterator( workingMemory,
handle ); it.hasNext(); ) {
final ReteTuple leftTuple = (ReteTuple) it.next();
final TupleMatch tupleMatch = attemptJoin( leftTuple,
handle,
objectMatches,
binder,
workingMemory );
if ( tupleMatch != null ) {
propagateAssertTuple( new ReteTuple( leftTuple,
handle ),
tupleMatch,
context,
workingMemory );
}
}
}
/**
* Retract a FactHandleImpl. Iterates the referenced TupleMatches stored in
* the handle's ObjectMatches retracting joined tuples.
*
* @param handle
* the <codeFactHandleImpl</code> being retracted
* @param context
* The <code>PropagationContext</code>
* @param workingMemory
* The working memory seesion.
*/
public void retractObject(final DefaultFactHandle handle,
final PropagationContext context,
final ReteooWorkingMemory workingMemory) {
final BetaMemory memory = (BetaMemory) workingMemory.getNodeMemory( this );
// Remove the FactHandle from memory
final ObjectMatches objectMatches = memory.remove( workingMemory,
handle );
for ( TupleMatch tupleMatch = objectMatches.getFirstTupleMatch(); tupleMatch != null; tupleMatch = (TupleMatch) tupleMatch.getNext() ) {
final ReteTuple leftTuple = tupleMatch.getTuple();
leftTuple.removeMatch( handle );
propagateRetractTuple( tupleMatch,
context,
workingMemory );
}
}
/**
* Retract a <code>ReteTuple</code>. Iterates the referenced
* <code>TupleMatche</code>'s stored in the tuples <code>Map</code>
* retracting all joined tuples.
*
* @param key
* The tuple key.
* @param context
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -