//# 0 errors, 18 messages
//#
/*
    //#PropertiesManager.java:1:1: class: org.apache.roller.weblogger.business.PropertiesManager
    //#PropertiesManager.java:1:1: method: org.apache.roller.weblogger.business.PropertiesManager.org.apache.roller.weblogger.business.PropertiesManager__static_init
 * Licensed to the Apache Software Foundation (ASF) under one or more
 *  contributor license agreements.  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.  For additional information regarding
 * copyright in this work, please see the NOTICE file in the top level
 * directory of this distribution.
 */

package org.apache.roller.weblogger.business;

import java.util.Map;
import org.apache.roller.weblogger.WebloggerException;
import org.apache.roller.weblogger.pojos.RuntimeConfigProperty;


/**
 * Manages global properties for Roller.
 */
public interface PropertiesManager {
    
    /**
     * Initialize the properties manager.
     *
     * @throws InitializationException If there is a problem during initialization.
     */
    public void initialize() throws InitializationException;
    
    
    /**
     * Release all resources associated with Roller session.
     */
    public void release();
    
    
    /**
     * Save a single property
     */
    public void saveProperty(RuntimeConfigProperty property) throws WebloggerException;
    
    
    /**
     * Save a list of properties
     */
    public void saveProperties(Map properties) throws WebloggerException;
    
    
    /**
     * Retrieve a single property by name
     */
    public RuntimeConfigProperty getProperty(String name) throws WebloggerException;
    
    
    /**
     * Retrieve a list of all properties
     */
    public Map getProperties() throws WebloggerException;
    
}
    //#output(org.apache.roller.weblogger.business.PropertiesManager__static_init): __Descendant_Table[org/apache/roller/weblogger/business/PropertiesManager]
    //#output(org.apache.roller.weblogger.business.PropertiesManager__static_init): __Dispatch_Table.getProperties()Ljava/util/Map;
    //#output(org.apache.roller.weblogger.business.PropertiesManager__static_init): __Dispatch_Table.getProperty(Ljava/lang/String;)Lorg/apache/roller/weblogger/pojos/RuntimeConfigProperty;
    //#output(org.apache.roller.weblogger.business.PropertiesManager__static_init): __Dispatch_Table.initialize()V
    //#output(org.apache.roller.weblogger.business.PropertiesManager__static_init): __Dispatch_Table.release()V
    //#output(org.apache.roller.weblogger.business.PropertiesManager__static_init): __Dispatch_Table.saveProperties(Ljava/util/Map;)V
    //#output(org.apache.roller.weblogger.business.PropertiesManager__static_init): __Dispatch_Table.saveProperty(Lorg/apache/roller/weblogger/pojos/RuntimeConfigProperty;)V
    //#post(org.apache.roller.weblogger.business.PropertiesManager__static_init): __Descendant_Table[org/apache/roller/weblogger/business/PropertiesManager] == &__Dispatch_Table
    //#post(org.apache.roller.weblogger.business.PropertiesManager__static_init): __Dispatch_Table.getProperties()Ljava/util/Map; == &getProperties
    //#post(org.apache.roller.weblogger.business.PropertiesManager__static_init): __Dispatch_Table.getProperty(Ljava/lang/String;)Lorg/apache/roller/weblogger/pojos/RuntimeConfigProperty; == &getProperty
    //#post(org.apache.roller.weblogger.business.PropertiesManager__static_init): __Dispatch_Table.initialize()V == &initialize
    //#post(org.apache.roller.weblogger.business.PropertiesManager__static_init): __Dispatch_Table.release()V == &release
    //#post(org.apache.roller.weblogger.business.PropertiesManager__static_init): __Dispatch_Table.saveProperties(Ljava/util/Map;)V == &saveProperties
    //#post(org.apache.roller.weblogger.business.PropertiesManager__static_init): __Dispatch_Table.saveProperty(Lorg/apache/roller/weblogger/pojos/RuntimeConfigProperty;)V == &saveProperty
    //#PropertiesManager.java:: end of method: org.apache.roller.weblogger.business.PropertiesManager.org.apache.roller.weblogger.business.PropertiesManager__static_init
    //#PropertiesManager.java:: end of class: org.apache.roller.weblogger.business.PropertiesManager
