~ubuntu-branches/ubuntu/saucy/commons-configuration/saucy

« back to all changes in this revision

Viewing changes to src/java/org/apache/commons/configuration/HierarchicalReloadableConfiguration.java

  • Committer: Package Import Robot
  • Author(s): Emmanuel Bourg
  • Date: 2013-07-01 16:29:44 UTC
  • mfrom: (1.1.4)
  • Revision ID: package-import@ubuntu.com-20130701162944-98waq5gogha5gpn1
Tags: 1.9-1
* New upstream release
* debian/control:
  - Updated Standards-Version to 3.9.4 (no changes)
  - Use canonical URLs for the Vcs-* fields
  - Added new build dependencies (libjavacc-maven-plugin-java, junit4)
  - Upgraded the dependency on the Servlet API (2.5 -> 3.0)
  - Removed the dependency on the Activation Framework (glassfish-activation)
  - Replaced the dependency on glassfish-mail with libgnumail-java
  - Removed the unused dependencies:
    liblog4j1.2-java-doc, libmaven-assembly-plugin-java
  - Replaced the dependency on libcommons-jexl-java by libcommons-jexl2-java
* debian/watch: Changed to point the official Apache distribution server
* Removed the obsolete file debian/ant.properties
* Installed the upstream changelog in the binary packages
* Added the report plugins to maven.ignoreRules
* Added the classpath attribute to the jar manifest

Show diffs side-by-side

added added

removed removed

Lines of Context:
1
 
/*
2
 
 * Licensed to the Apache Software Foundation (ASF) under one or more
3
 
 * contributor license agreements.  See the NOTICE file distributed with
4
 
 * this work for additional information regarding copyright ownership.
5
 
 * The ASF licenses this file to You under the Apache License, Version 2.0
6
 
 * (the "License"); you may not use this file except in compliance with
7
 
 * the License.  You may obtain a copy of the License at
8
 
 *
9
 
 *     http://www.apache.org/licenses/LICENSE-2.0
10
 
 *
11
 
 * Unless required by applicable law or agreed to in writing, software
12
 
 * distributed under the License is distributed on an "AS IS" BASIS,
13
 
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
14
 
 * See the License for the specific language governing permissions and
15
 
 * limitations under the License.
16
 
 */
17
 
package org.apache.commons.configuration;
18
 
 
19
 
import org.apache.commons.configuration.reloading.Reloadable;
20
 
 
21
 
/**
22
 
 * <p>A base class for hierarchical configurations with specific reloading
23
 
 * requirements.</p>
24
 
 * <p>This class manages a lock object which can be used for synchronization.</p>
25
 
 *
26
 
 * @author <a
27
 
 *         href="http://commons.apache.org/configuration/team-list.html">Commons
28
 
 *         Configuration team</a>
29
 
 * @since 1.7
30
 
 * @version $Id: HierarchicalReloadableConfiguration.java 1162387 2011-08-27 16:05:20Z oheger $
31
 
 */
32
 
public class HierarchicalReloadableConfiguration extends HierarchicalConfiguration
33
 
    implements Reloadable
34
 
{
35
 
    /** Constant for the name used for the lock object. */
36
 
    private static final String LOCK_NAME = "HierarchicalReloadableConfigurationLock";
37
 
 
38
 
    /** The lock object used by this instance. */
39
 
    private final Object reloadLock;
40
 
 
41
 
    /**
42
 
     * Creates a new instance of <code>HierarchicalReloadableConfiguration</code>.
43
 
     */
44
 
    public HierarchicalReloadableConfiguration()
45
 
    {
46
 
        super();
47
 
        reloadLock = new Lock(LOCK_NAME);
48
 
    }
49
 
 
50
 
    /**
51
 
     * Creates a new instance of
52
 
     * <code>HierarchicalReloadableConfiguration</code> and initializes it with
53
 
     * the given lock object.
54
 
     *
55
 
     * @param lock the lock object
56
 
     */
57
 
    public HierarchicalReloadableConfiguration(Object lock)
58
 
    {
59
 
        super();
60
 
        reloadLock = lock == null ? new Lock(LOCK_NAME) : lock;
61
 
    }
62
 
 
63
 
    /**
64
 
     * Creates a new instance of <code>HierarchicalConfiguration</code> and
65
 
     * copies all data contained in the specified configuration into the new
66
 
     * one.
67
 
     *
68
 
     * @param c the configuration that is to be copied (if <b>null</b>, this
69
 
     * constructor will behave like the standard constructor)
70
 
     */
71
 
    public HierarchicalReloadableConfiguration(HierarchicalConfiguration c)
72
 
    {
73
 
        super(c);
74
 
        reloadLock = new Lock(LOCK_NAME);
75
 
    }
76
 
 
77
 
    public Object getReloadLock()
78
 
    {
79
 
        return reloadLock;
80
 
    }
81
 
}