Return-Path: Delivered-To: apmail-commons-commits-archive@minotaur.apache.org Received: (qmail 33731 invoked from network); 1 Feb 2011 21:21:21 -0000 Received: from hermes.apache.org (HELO mail.apache.org) (140.211.11.3) by minotaur.apache.org with SMTP; 1 Feb 2011 21:21:21 -0000 Received: (qmail 8299 invoked by uid 500); 1 Feb 2011 21:21:21 -0000 Delivered-To: apmail-commons-commits-archive@commons.apache.org Received: (qmail 8194 invoked by uid 500); 1 Feb 2011 21:21:20 -0000 Mailing-List: contact commits-help@commons.apache.org; run by ezmlm Precedence: bulk List-Help: List-Unsubscribe: List-Post: List-Id: Reply-To: dev@commons.apache.org Delivered-To: mailing list commits@commons.apache.org Received: (qmail 8187 invoked by uid 99); 1 Feb 2011 21:21:20 -0000 Received: from athena.apache.org (HELO athena.apache.org) (140.211.11.136) by apache.org (qpsmtpd/0.29) with ESMTP; Tue, 01 Feb 2011 21:21:20 +0000 X-ASF-Spam-Status: No, hits=-2000.0 required=5.0 tests=ALL_TRUSTED X-Spam-Check-By: apache.org Received: from [140.211.11.4] (HELO eris.apache.org) (140.211.11.4) by apache.org (qpsmtpd/0.29) with ESMTP; Tue, 01 Feb 2011 21:21:19 +0000 Received: by eris.apache.org (Postfix, from userid 65534) id 9817023889EA; Tue, 1 Feb 2011 21:20:59 +0000 (UTC) Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 8bit Subject: svn commit: r1066211 - /commons/sandbox/digester3/trunk/src/main/java/org/apache/commons/digester3/rules/AbstractRulesImpl.java Date: Tue, 01 Feb 2011 21:20:58 -0000 To: commits@commons.apache.org From: simonetripodi@apache.org X-Mailer: svnmailer-1.0.8 Message-Id: <20110201212059.9817023889EA@eris.apache.org> Author: simonetripodi Date: Tue Feb 1 21:20:52 2011 New Revision: 1066211 URL: http://svn.apache.org/viewvc?rev=1066211&view=rev Log: first checkin of AbstractRulesImpl class Added: commons/sandbox/digester3/trunk/src/main/java/org/apache/commons/digester3/rules/AbstractRulesImpl.java (with props) Added: commons/sandbox/digester3/trunk/src/main/java/org/apache/commons/digester3/rules/AbstractRulesImpl.java URL: http://svn.apache.org/viewvc/commons/sandbox/digester3/trunk/src/main/java/org/apache/commons/digester3/rules/AbstractRulesImpl.java?rev=1066211&view=auto ============================================================================== --- commons/sandbox/digester3/trunk/src/main/java/org/apache/commons/digester3/rules/AbstractRulesImpl.java (added) +++ commons/sandbox/digester3/trunk/src/main/java/org/apache/commons/digester3/rules/AbstractRulesImpl.java Tue Feb 1 21:20:52 2011 @@ -0,0 +1,72 @@ +/* $Id$ + * + * Licensed to the Apache Software Foundation (ASF) under one or more + * contributor license agreements. See the NOTICE file distributed with + * this work for additional information regarding copyright ownership. + * The ASF licenses this file to You 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.apache.commons.digester3.rules; + +import org.apache.commons.digester3.Digester; +import org.apache.commons.digester3.Rule; +import org.apache.commons.digester3.spi.Rules; + +/** + * {@code AbstractRuleImpl} provides basic services for {@code Rules} implementations. + * + * Extending this class should make it easier to create a {@codeƊRules} implementation. + * + * {@code AbstractRuleImpl} manages the {@code Digester} + * If the subclass overrides {@link #registerRule} (rather than {@link #add}), + * then the Digester and namespaceURI of the Rule + * will be set correctly before it is passed to registerRule. + * The subclass can then perform whatever it needs to do to register the rule.

+ */ +abstract class AbstractRulesImpl implements Rules { + + /** + * Digester using this {@code Rules} implementation. + */ + private Digester digester; + + /** + * {@inheritDoc} + */ + public void add(String pattern, Rule rule) { + if (this.digester != null && rule != null) { + rule.setDigester(this.digester); + } + this.registerRule(pattern, rule); + } + + /** + * Register rule at given pattern. + * The the Digester and namespaceURI properties of the given Rule + * can be assumed to have been set properly before this method is called. + * + * @param pattern Nesting pattern to be matched for this Rule + * @param rule Rule instance to be registered + */ + protected abstract void registerRule(String pattern, Rule rule); + + /** + * {@inheritDoc} + */ + public void setDigester(Digester digester) { + this.digester = digester; + for (Rule rule : this.rules()) { + rule.setDigester(digester); + } + } + +} Propchange: commons/sandbox/digester3/trunk/src/main/java/org/apache/commons/digester3/rules/AbstractRulesImpl.java ------------------------------------------------------------------------------ svn:eol-style = native Propchange: commons/sandbox/digester3/trunk/src/main/java/org/apache/commons/digester3/rules/AbstractRulesImpl.java ------------------------------------------------------------------------------ svn:keywords = Date Author Id Revision HeadURL Propchange: commons/sandbox/digester3/trunk/src/main/java/org/apache/commons/digester3/rules/AbstractRulesImpl.java ------------------------------------------------------------------------------ svn:mime-type = text/plain