/*************************************************************************** * Copyright (C) 2011 by Fabrizio Montesi <famontesi@gmail.com> * * * * This program is free software; you can redistribute it and/or modify * * it under the terms of the GNU Library General Public License as * * published by the Free Software Foundation; either version 2 of the * * License, or (at your option) any later version. * * * * This program is distributed in the hope that it will be useful, * * but WITHOUT ANY WARRANTY; without even the implied warranty of * * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * * GNU General Public License for more details. * * * * You should have received a copy of the GNU Library General Public * * License along with this program; if not, write to the * * Free Software Foundation, Inc., * * 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. * * * * For details about the authors of this software, see the AUTHORS file. * ***************************************************************************/ package jolie.runtime.correlation; import java.util.List; import java.util.Set; import jolie.runtime.VariablePath; import jolie.util.MultiMap; /** * * @author Fabrizio Montesi */ public class CorrelationSet { public static class CorrelationPair { private final VariablePath sessionPath; private final VariablePath messagePath; public CorrelationPair( VariablePath sessionPath, VariablePath messagePath ) { this.sessionPath = sessionPath; this.messagePath = messagePath; } public VariablePath sessionPath() { return sessionPath; } public VariablePath messagePath() { return messagePath; } } // Maps operation names to their correlation pairs. private final MultiMap< String, CorrelationPair > correlationMap; private final List< VariablePath > correlationVariablePaths; public CorrelationSet( List< VariablePath > correlationVariablePaths, MultiMap< String, CorrelationPair > correlationMap ) { this.correlationMap = correlationMap; this.correlationVariablePaths = correlationVariablePaths; } /** * Returns the list of {@link CorrelationPair} defined for the operation. * @param operationName the operation name the list is defined for. * @return the list of {@link CorrelationPair} defined for the operation, or {@code null} if no such list is defined. */ public List< CorrelationPair > getOperationCorrelationPairs( String operationName ) { return (List< CorrelationPair >)correlationMap.get( operationName ); } public List< VariablePath > correlationVariablePaths() { return correlationVariablePaths; } public Set< String > correlatingOperations() { return correlationMap.keySet(); } }