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