/** * 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. */ package org.drools; import org.drools.rule.Rule; /** * Indicates an error integrating a <code>Rule</code> or <code>Package</code> * into a <code>RuleBase</code>. * * @see RuleBase#addRule * @see RuleBase#addPackage * * @author <a href="mailto:bob@eng.werken.com">bob mcwhirter </a> * * @version $Id: RuleIntegrationException.java,v 1.6 2004/09/17 00:14:06 * mproctor Exp $ */ public class RuleIntegrationException extends IntegrationException { /** * */ private static final long serialVersionUID = 510l; /** The rule. */ private final Rule rule; /** * @see java.lang.Exception#Exception() * * @param rule * The offending rule. */ public RuleIntegrationException(final Rule rule) { super( createMessage( rule ) ); this.rule = rule; } /** * @see java.lang.Exception#Exception(Throwable cause) * * @param rule * The offending rule. */ public RuleIntegrationException(final Rule rule, final Throwable cause) { super( createMessage( rule ), cause ); this.rule = rule; } /** * Retrieve the <code>Rule</code>. * * @return The rule. */ public Rule getRule() { return this.rule; } private static String createMessage(final Rule rule) { return rule.getName() + " cannot be integrated"; } }